在我的视图模型中,我有一个对象列表.我迭代这些对象,并为每个对象创建控件.在下面的情况中,我想向人们展示每个对象的文本框和按钮.当用户单击该按钮时,会发布一个帖子,我可以将数据保存在我的控制器中.
在UI中,用户可以更改他们想要的表单,然后单击“保存”.
我的问题是当模型发布到控制器时模型为空.
我的剃刀代码:
using (Html.BeginForm()) { foreach (var contributor in Model.Contributor) { @Html.HiddenFor(model => contributor.Id) <div class="formrow"> @Html.ValidationSummary(true) </div> <h2>@Html.TextRaw("AuthorInfo","Author")</h2> <div class="formrow"> @Html.EditorFor(model => contributor.FirstName) <div class="formvalidation"> @Html.ValidationMessageFor(model => contributor.FirstName) </div> </div> <div class="formrow right"> <input type="hidden" name="formsubmitted" value="true" /> <input type="submit" class="button" value="@Html.Text("ButtonText","Save")" /> </div> } }
我的视图模型代码
public class ProfileModel { public string Message { get; set; } public List<PublisherModel> Publisher { get; set; } public List<ContributorModel> Contributor { get; set; } public ContributorModel NewContributor { get; set; } }
我的控制器代码
[HttpPost] public ActionResult Mine(ProfileModel model,string newuser) { // }
怎么解决?
我想我必须扩展我的视图模型,以某种方式存储更改.但我真的看不出怎么样.
现在,ProfileModel中的所有属性在到达控制器时都为null.
有任何想法吗?
解决方法
基本上问题是默认模型绑定器无法在foreach循环中正确绑定集合项.换句话说,它错误地命名元素,这就是集合在参数中显示为null的原因.
我确信有各种不同的解决方法,帮助器和东西,但我不熟悉那些,所以我只是使用for循环而不是foreach,这样元素被正确命名.
试试这个:
@for (int i = 0; i < Model.Contributor.Count(); i++) { @Html.HiddenFor(model => Model.Contributor[i].Id) <div class="formrow"> @Html.ValidationSummary(true) </div> <h2>@Html.TextRaw("AuthorInfo","Author")</h2> <div class="formrow"> @Html.EditorFor(model => Model.Contributor[i].FirstName) <div class="formvalidation"> @Html.ValidationMessageFor(model => Model.Contributor[i].FirstName) </div> </div> <div class="formrow right"> <input type="hidden" name="formsubmitted" value="true" /> <input type="submit" class="button" value="@Html.Text("ButtonText","Save")" /> </div> }
我建议您使用调试工具来查看元素是否具有正确的name属性,在您的情况下,它们应该看起来像Contributor [0] .Id,Contributor [0] .FirstName等.