ViewModelを使ってビューにオブジェクトを渡す
コントローラーからビューに値を渡す方法として、ViewData()やTempData()がありますが、これらは一つのパラメーターしか渡すことができません。
複数のパラメーターをビューに渡すには、ViewModelを使います。
以下に、ViewModelの作成手順と使い方を記述します。
ViewModelの作成
ViewModelは、クラスとして定義します。
ソリューションエクスプローラーからModelsフォルダにカーソルを合わせます。
data:image/s3,"s3://crabby-images/aed5e/aed5ecc59464be981924a72e13cf09a5e4ab7eb8" alt="vbmvc4-1"
右クリックして、「追加」→「クラス」を選択します。
data:image/s3,"s3://crabby-images/bbc06/bbc060620ec6a74e563018dbed63786448436fea" alt="vbmvc4-2"
クラスが選択されていることを確認して、名前を入力し、「追加」ボタンを押下します。
※クラス名は、コントローラーと違い自由に付けることができますが、ViewModelであることが分かる名称にします。
data:image/s3,"s3://crabby-images/f13e3/f13e3a0054171e699bc02479a504d572552c4fb8" alt="vbmvc4-3"
Modelsフォルダ配下に、クラスが作成されます。
data:image/s3,"s3://crabby-images/03420/03420dcb0f9cb0cffc5bc5c87e4485b300597353" alt="vbmvc4-4"
ViewModelの編集
作成したViewModelのクラスをダブルクリックして、以下のように編集します。
ViewModelに定義する値は、ビューで使用するため「Public Property」にします。
1 2 3 4 5 |
Public Class HomeViewModel Public Property Name As String Public Property Address As String Public Property Birthday As Date End Class |
コントローラーの編集
ViewModelを作成したら、コントローラーでViewModelが使えるようにインスタンス化して、値を設定します。
View()の引数として、インスタンス化したViewModelを渡します。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 |
Imports System.Web.Mvc Namespace Controllers Public Class HomeController Inherits Controller Function Index() As ActionResult Dim vm As New HomeViewModel() vm.Name = "山田太郎" vm.Address = "東京都千代田区丸の内1-1-1" vm.Birthday = "2000/1/1" Return View(vm) End Function End Class End Namespace |
ビューの編集
ビューでViewModelを受け取るために、ViewModelの型を指定する必要があります。
ビューの先頭行に、以下のような記述をします。
@ModelType ViewModel名
ビューが受け取ったViewModelは、ビュー内でModelオブジェクトに紐づけられます。
1 2 3 4 5 6 7 8 |
@ModelType HomeViewModel @Code ViewData("Title") = "Index" End Code <h2>@Model.Name</h2> <h2>@Model.Address</h2> <h2>@Model.Birthday</h2> |
プログラムの実行
プログラムを実行すると、以下のようにコントローラーで設定した値が表示されます。
data:image/s3,"s3://crabby-images/0ea1a/0ea1af398e9f4463be7d57fe2ad0b9a7e0722f61" alt="vbmvc4-5"