IEnumerableプロパティを持つモデルがあります(従うべき擬似コードを警告します)
public class PersonModel {
public string Name { get; set; }
public IEnumerable<AddressModel> Addresses { get; set; }
}
public class AddressModel {
public string Name { get; set; }
}
同じビューにアドレスサブオブジェクトを表示したい
Person.cshtml
@model PersonModel
<form>
<h2>Person</h2>
@Html.EditorFor(m=>m.Name)
<ul>@Html.EditorFor(m=>m.Addresses)</ul>
</form>
EditorTemplate / AddressModel
@model AddressModel
<li>@Html.TextboxFor(m=>m.Name)</li>
マーベラス、すべて正常に動作します
しかし、Gitであるため、テンプレートレイアウトを使用して、すべてのプロパティを標準タイプの方法でラップし始めたいと思います。
そこで、これを行うためにstring.cshtmlとlist.cshtmlを作成し、レイアウトに_Control.cshtmlを使用します
EditorTemplates / _Control.cshtml
<div>
@Html.Label(string.Empty)
<div class="input">
@RenderBody()
@Html.ValidationMessage(string.Empty)
</div>
</div>
EditorTemplates / string.cshtml
@model string
@{
Layout = "_Control.cshtml";
}
@Html.TextBox(string.Empty, Model)
(これまでのところイェーイ!でも待って..ああ、いや..)
これが問題です
<ul>@Html.EditorFor(m=>m.Addresses)</ul>
メインビュー(上記を参照)から
@Html.EditorFor(m=>m.Addresses, "List")
EditorTemplates / list.cshtml
@model IEnumerable<object>
@{
Layout = "_Control.cshtml";
}
<ul>
@foreach(var item in Model){
@Html.EditorFor(m => item)
}
</ul>
これにより、IDと名前が正しくレンダリングされません。たとえば、Addresses_item_NameのようにIDが含まれていないため、forループを使用してIDを追加します。
@for (var i = 0; i < Model.Count();i++ ) {
@Html.EditorFor(m => Model.ElementAt(i))
}
これは、MVC式ヘルパーが配列以外のものを許可しないために爆発しますが、EF4.1はサブクエリ内の.ToArrayをサポートしていないため、アドレスはIEnumerable<>である必要があります。
var model = (from p in DataContext.People
where p.Id = 1
select new PersonModel {
Name = p.Name,
Addresses = (from a in p.Addresses
select new AddressModel {
Name = a.Name
}).ToArray() // **NOT SUPPORTED**
}).FirstOrDefault();
誰かがこれに反対しましたか?それを行うための標準的な方法はありますか?
これは機能しますが、正しいですか?
EditorTemplates / list.cshtml
@model IEnumerable<object>
@{
Layout = "_Control.cshtml";
var prefix = ViewData.TemplateInfo.HtmlFieldPrefix;
}
<ul>
@for (var i = 0; i < Model.Count();i++ ) {
var item = Model.ElementAt(i);
ViewData.TemplateInfo.HtmlFieldPrefix = string.Format("{0}[{1}]",prefix, i);
@Html.EditorFor(m => item, null, string.Empty)
}
</ul>
望ましい構造は
<form>
<control>
Person Name Control Elements
<control>
<control>
Address List Control Elements
<control>
</form>