.NETエンジニア・プログラマ向けの技術情報・業界ニュースをお届けします。

  1. FEnet.NETナビ
  2. .NETコラム
  3. プログラミング言語
  4. C#
  5. C#でのMVCについて紹介|C#でMVCWebアプリケーションを作成しましょう

C#でのMVCについて紹介|C#でMVCWebアプリケーションを作成しましょう

  • C#
  • プログラミング言語
公開日時:   更新日時:
C#でのMVCについて紹介|C#でMVCWebアプリケーションを作成しましょう
この記事でわかること
    基本情報技術者試験の試験対策はこちら>>

    システム
    エンジニア
    MVCとは何かよく理解できません。教えてください。

    プロジェクト
    マネージャー
    わかりました。では、詳しくみていきましょう。

    C#のMVCについて


    今回は、C#でのMVCについて説明します。

    MVCとは、Webフレームワークで一般的に取り入れられている概念です。
    モデル(Model)、ビュー(View)、コントローラー(Controller)の頭文字でMVCです。
    モデルは、ロジックを記述します。
    ビューは、画面表示の役割を持ちます。
    コントローラーは、画面遷移などを管理します。

    C#でのMVCとは、ASP.netを用いたMVC Webアプリケーションのことです。
    Visual Studioを使うと、C# MVCプロジェクトのひな形を作ってくれます。
    今回は、Visual Studio Community 2019をインストールしている前提で進めます。

    C#のMVCに興味のある方はぜひご覧ください。

    プロジェクトの作成

    Visual Studioでプロジェクトを作成します。
    1. ASP.NET Webアプリケーション(.NET Framework)を選択し、[次へ]ボタンをクリックします。

    2. プロジェクト名を入力します。
    ここでは、デフォルトの[WebApplication1]のままとして、[作成(C)]ボタンをクリックします。

    3. プロジェクトテンプレートを選択します。
    [空]を選択します。
    また、MVC(M)にチェックを付けます。
    [作成]ボタンをクリックします。

    プロジェクトが作成され、以下のようなファイル構成となります。

    コントローラーの作成

    プロジェクトを作成しましたので、次にコントローラーを作成します。
    C#でのMVCの”C”の部分です。

    1. コントローラを追加します。
    ソリューションエクスプローラーで[Controllers]フォルダを右クリックします。
    [追加(D)]→[コントローラー(T)]の順に選択します。

    2. 新規スキャフォールディングアイテムを追加します。
    [MVC 5 コントローラー]を選択して[追加]ボタンをクリックします。

    3. コントローラ名を入力します。
    ここでは、[DefaultController]のままで[追加]ボタンをクリックします。

    コントローラが追加され、DefaultController.csが開きます。
    下記のコードが自動生成されます。

    ビューの作成

    次にビューを作成します。
    C#でのMVCの”V”の部分です。

    1. ビューを追加します。
    ソリューションエクスプローラーで[Views\Default]フォルダを右クリックします。
    [追加(D)]→[ビュー(V)]の順に選択します。

    2. [ビューの追加]ダイアログが表示されます。
    ビュー名をViewからIndexに変更します。
    [レイアウトページの使用(U)]のチェックを外します。
    [追加]ボタンをクリックします。

    ビューが追加され、Index.cshtmlが開きます。
    下記のコードが自動生成されます。

    プロジェクトを実行してみましょう。
    “(Webアプリケーションのルートディレクトリ)/Default/Index” URLにアクセスすると、真っ白なページが表示されます。
    エラーが表示されなければ成功しています。
    index.cshtmlのbody部に何か記述すると、成功していることが分かりやすいです。

    モデルの作成

    モデルを作成します。
    C#でのMVCの”M”の部分です。

    1. モデルを追加します。
    ソリューションエクスプローラーで[Models]フォルダを右クリックします。
    [追加(D)]→[新しい項目(W)]の順に選択します。

    2. [新しい項目の追加]ダイアログボックスが表示されます。
    [Web]→[コード]ノードをクリックします。
    [クラス]を選択し、[追加]ボタンをクリックします。

    モデルが追加され、Class1.csが開きます。
    下記のコードが自動生成されます。

    3. モデルクラスを実装します。
    クラスのメンバ変数を実装します。

    ここではstring型のName、int型のAgeを実装しました。

    4. ビューを追加します。
    ソリューションエクスプローラーで[Views\Default]フォルダを右クリックします。
    [追加(D)]→[ビュー(V)]の順に選択します。

    5. [ビューの追加]ダイアログが表示されます。
    [ビュー名(N)]をHumanに変更します。
    [テンプレート(T)]をEmptyに変更します。
    [モデル クラス(M)]をClass1に変更します。
    [追加]ボタンをクリックします。

    ビューが追加され、Human.cshtmlが開きます。
    下記のコードが自動生成されます。

    6. コントローラーの実装
    コントローラーを実装します。

    Humanメソッドを新規に作成します。
    追加したViewと同じ名前になるようにしてください。

    プロジェクトを実行してみましょう。
    “(Webアプリケーションのルートディレクトリ)/Default/Human” URLにアクセスすると、
    Taro
    30
    が表示されます。

    システム
    エンジニア
    MVCとはWebアプリケーションを作成するためのデザインパターンということですね?

    プロジェクト
    マネージャー
    そうです。プロジェクト作成で雛形を作ってくれるので、大変便利なプログラミングです。

    まとめ

    いかがでしたでしょうか。
    C#でのMVCとは、ASP.netを用いたMVC Webアプリケーションのことです。
    MVCとは、Webフレームワークで一般的に取り入れられている概念です。
    Visual Studio 2019を使った、C#でのMVCアプリケーションについて説明しました。
    ぜひご自身でC#のソースコードを書いて、理解を深めてください。

    FEnet.NETナビ・.NETコラムは株式会社オープンアップシステムが運営しています。
    株式会社オープンアップシステムロゴ

    株式会社オープンアップシステムはこんな会社です

    秋葉原オフィスには株式会社オープンアップシステムをはじめグループのIT企業が集結!
    数多くのエンジニアが集まります。

    秋葉原オフィスイメージ
    • スマホアプリから業務系システムまで

      スマホアプリから業務系システムまで

      スマホアプリから業務系システムまで開発案件多数。システムエンジニア・プログラマーとしての多彩なキャリアパスがあります。

    • 充実した研修制度

      充実した研修制度

      毎年、IT技術のトレンドや社員の要望に合わせて、カリキュラムを刷新し展開しています。社内講師の丁寧なサポートを受けながら、自分のペースで学ぶことができます。

    • 資格取得を応援

      資格取得を応援

      スキルアップしたい社員を応援するために資格取得一時金制度を設けています。受験料(実費)と合わせて資格レベルに合わせた最大10万円の一時金も支給しています。

    • 東証プライム上場企業グループ

      東証プライム上場企業グループ

      オープンアップシステムは東証プライム上場「株式会社夢真ビーネックスグループ」のグループ企業です。

      安定した経営基盤とグループ間のスムーズな連携でコロナ禍でも安定した雇用を実現させています。

    株式会社オープンアップシステムに興味を持った方へ

    株式会社オープンアップシステムでは、開発系エンジニア・プログラマを募集しています。

    年収をアップしたい!スキルアップしたい!大手の上流案件にチャレンジしたい!
    まずは話だけでも聞いてみたい場合もOK。お気軽にご登録ください。

    株式会社オープンアップシステムへのご応募はこちら↓
    株式会社オープンアップシステムへのご応募はこちら↓

    C#新着案件New Job