現在、アルバムクラスの作成ビューしかありません。
@model MvcApplication1.Models.AlbumViewModel
@{
ViewBag.Title = "Index";
}
<h2>Index</h2>
<script src="@Url.Content("~/Scripts/jquery.validate.min.js")" type="text/javascript"></script>
<script src="@Url.Content("~/Scripts/jquery.validate.unobtrusive.min.js")" type="text/javascript"></script>
@using (Html.BeginForm()) {
@Html.ValidationSummary(true)
<fieldset>
<legend>AlbumViewModel</legend>
<p>
@Html.LabelFor(model => model.GenreId)
@Html.DropDownListFor(x => x.GenreId, new SelectList(Model.Genres, "GenreId", "name"))
</p>
<p>
@Html.LabelFor(model => model.ArtistId)
@Html.DropDownListFor(x => x.ArtistId, new SelectList(Model.Artists, "ArtistId", "Name"))
</p>
<p>
<input type="submit" value="Create" />
</p>
</fieldset>
}
<div>
@Html.ActionLink("Back to List", "Index")
</div>
将来の時間を節約するために、作成と編集の両方にEditorForを使用するのが慣例であると言われています。
したがって、私のビューは次のようになります。
@model MvcApplication1.Models.AlbumViewModel
@{
ViewBag.Title = "Index";
}
<h2>Index</h2>
<script src="@Url.Content("~/Scripts/jquery.validate.min.js")" type="text/javascript"></script>
<script src="@Url.Content("~/Scripts/jquery.validate.unobtrusive.min.js")" type="text/javascript"></script>
@Html.EditorForModel
<div>
@Html.ActionLink("Back to List", "Index")
</div>
これは正しいです?これをどのように、どこで宣言し、ソリューションに記述しますか?
編集:
メインのアカウント/登録ビューにこれがあります:
@model Models.RegisterViewModel
@{
ViewBag.Title = "Register";
}
<h2>Register</h2>
<script src="@Url.Content("~/Scripts/jquery.validate.min.js")" type="text/javascript"></script>
<script src="@Url.Content("~/Scripts/jquery.validate.unobtrusive.min.js")" type="text/javascript"></script>
@using (Html.BeginForm()) {
@Html.ValidationSummary(true)
<fieldset>
<legend>RegisterViewModel</legend>
@Html.EditorFor(model => model.RegisterModel)
@Html.EditorFor(model => model.Cities)
@Html.EditorFor(model => model.Countries)
<p>
<input type="submit" value="Create" />
</p>
</fieldset>
}
そして私のEditorTemplateで:
@model Fooer.WebUI.Models.RegisterModel
THIS IS A TEST.
それでも、そのダミーテキストはまったくレンダリングされません。モデルのデフォルトのコントロールをレンダリングします。