MVC3部分视图和模型不回发更改

时间:2011-10-07 12:58:55

标签: c# asp.net-mvc-3

我的模型包含一组可以修改的项目。

我使用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

2 个答案:

答案 0 :(得分:5)

如果检查渲染的源,是否可以检查渲染的子模型输入的名称和ID是否与模型层次结构相对应?

我相信您需要EditorFor才能使子模型正确“命名空间”。

因此,在EventModel视图中,使用以下内容:

@Html.EditorFor(m => m.Team1Players, "EventPlayers")
但是,我不确定。我在MVC框架方面遇到了类似的问题。

答案 1 :(得分:0)

问题可能出在集合绑定中。

尝试阅读this post。它应该给你一些关于集合绑定的见解