我的模型包含一组可以修改的项目。
我使用Partial View渲染集合,而Partial View又使用EditorForModel输出集合中每个元素的HTML。
@model Footy.Models.EventModel
<h2>@Model.Team1Name vs @Model.Team2Name</h2>
@using (Html.BeginForm("Index", "Event"))
{
@Html.HiddenFor(m => m.EventID)
<h1>
Team 1 Squad</h1>
@Html.Partial("EventPlayers", Model.Team1Players);
<h1>
Team 2 Squad</h1>
Html.RenderPartial("EventPlayers", Model.Team2Players);
<input type="submit" value="Confirm Changes" />
}
部分视图
@model IEnumerable<Footy.Models.PlayerModel>
@Html.EditorForModel()
PlayerModel View
@model Footy.Models.PlayerModel
@Model.PlayerName @Html.DropDownListFor(p => p.ParticipationStatusID, new SelectList(Model.ParticipationTypes, "Key", "Value"))
这一切都正确呈现,但是当用户点击输入时,控制器方法不会传递模型中的子集合,例如Model.Team1Players为null
我错过了什么?
编辑:生成的HTML
<form action="/Footy/Event/Index/1" method="post"><input data-val="true" data-val-number="The field EventID must be a number." data-val-required="The EventID field is required." id="EventID" name="EventID" type="hidden" value="1" />
<h1>Team 1 Squad</h1>
si <select data-val="true" data-val-number="The field ParticipationStatusID must be a number." data-val-required="The ParticipationStatusID field is required." name="[0].ParticipationStatusID"><option value="1">Team</option>
<option value="2">Sub</option>
<option value="3">Squad</option>
</select>
<h1>Team 2 Squad</h1>
<input type="submit" value="Confirm Changes" />
</form>
由于
我认为这与这个问题有关,而这个问题还没有答案:Posting data back to a controller from a Partial View rendered by Ajax
答案 0 :(得分:5)
如果检查渲染的源,是否可以检查渲染的子模型输入的名称和ID是否与模型层次结构相对应?
我相信您需要EditorFor
才能使子模型正确“命名空间”。
因此,在EventModel视图中,使用以下内容:
@Html.EditorFor(m => m.Team1Players, "EventPlayers")
但是,我不确定。我在MVC框架方面遇到了类似的问题。
答案 1 :(得分:0)
问题可能出在集合绑定中。
尝试阅读this post。它应该给你一些关于集合绑定的见解