我正在尝试编辑嵌套集合并将值发布回服务器。 我不知道这是否可能。
Class1有一个Class2
的集合Class2有Class3
Class3有一个Class4
的集合Class4有一个Class5
的集合我从Nuget安装了包BeginCollectionItem。
我为每个人创建了编辑器模板。 但仍然没有显示编辑器。
@using (Html.BeginForm("SaveModification","Client", FormMethod.Post, new { @class = "form-horizontal", role = "form" }))
{
@Html.AntiForgeryToken()
@Html.HiddenFor(o => o.Id)
<div class="row">
<div class="col-md-12">
@using (Html.BeginCollectionItem("Classes2"))
{
@Html.EditorFor(x => x.Classes2)
}
</div>
</div>
<div class="row">
<div class="col-md-offset-2 col-md-10">
<input type="submit" value="Save" class="btn btn-default" />
</div>
</div>
}
Class2.cshtml
<div class="row">
@Html.HiddenFor(o => o.Id)
@Html.EditorFor(model => model.Class3)
</div>
Class3.cshtml
<div class="row">
@Html.HiddenFor(o=>o.Id)
<div class="row">
<div class="col-md-10" >@Html.DisplayFor(model => model.Name)</div>
<div class="col-md-2">@Html.EditorFor(model => model.Quantity)</div>
</div>
<div class="row">
@using (Html.BeginCollectionItem("Classes4"))
{
@Html.EditorFor(x => x.Classes4)
}
</div>
</div>
Class4.cshtml
<div class="row">
<div class="col-md-10" style="padding-left:30px;">@Html.DisplayFor(model => model.Name)</div>
<div class="col-md-2">@Html.EditorFor(model => model.Quantity)</div>
</div>
<div class="row">
@using (Html.BeginCollectionItem("Classes5"))
{
@Html.EditorFor(x => x.Classes5)
}
</div>
Class5.cshtml
@Html.HiddenFor(model => model.Id)
<div class="row">
<div class="col-md-10" style="padding-left:50px;">@Html.DisplayFor(model => model.Name)</div>
<div class="col-md-2">@Html.EditorFor(model => model.Quantity)</div>
</div>
我的问题:这是否可以使用嵌套编辑器模板?
更新1:
使用fiddler,我看到我的回复包含我编辑的值
Id
Classes2.index
Classes2.index
Classes2[311410b2-6ce1-4a09-9979-552720f377fc].Id
Classes2[311410b2-6ce1-4a09-9979-552720f377fc].Class3.Id
Classes2[311410b2-6ce1-4a09-9979-552720f377fc].Class3.Quantity
Class3.index
Class3[7e8b7a76-7000-4ec9-8877-d150ffe25dc5].Classes4.index
Class3[7e8b7a76-7000-4ec9-8877-d150ffe25dc5].Classes4[3315b9ce-989d-4229-92c5-a7ba9955539d].Id
Class3[7e8b7a76-7000-4ec9-8877-d150ffe25dc5].Classes4[3315b9ce-989d-4229-92c5-a7ba9955539d].Quantity
Classes4.index
Classes4[d8990f17-9d9d-4f21-81e2-70c012c48922].Classes5.index
Classes4[d8990f17-9d9d-4f21-81e2-70c012c48922].Classes5[a8afe9a0-b6e0-42b7-85aa-f5bd967dcab6].Id
Classes4[d8990f17-9d9d-4f21-81e2-70c012c48922].Classes5[a8afe9a0-b6e0-42b7-85aa-f5bd967dcab6].Quantity
但是在我的控制器中,viewmodel没有相同的值,有些集合为null。我只获得class2和class3值。
答案 0 :(得分:1)
BeginCollectionItem
应该用于单个集合项,而不是集合级别。此外,如果您只想显示集合而不动态添加和删除,则不需要它。
在主视图中,您可以这样做:
<div class="col-md-12">
@Html.EditorFor(x => x.Classes2)
</div>
调用EditorTemplate Class2.cshtml
。 Razor将自动循环收集并为每个元素渲染模板。
如果需要,可以在Class2.cshtml
中将代码包装到:
@using (Html.BeginCollectionItem("Classes2"))
{
// Your Template code here...
}