使用Razor在POST上使用Model.List为null
我的看法:
@foreach(var item in Model.List) { @Html.HiddenFor(model => item.UserId) @Html.HiddenFor(model => item.Name) @Html.HiddenFor(model => item.Age) @Html.CheckBoxFor(model => item.IsChecked, new { id = item.UserId }) }
我的控制器:
[HttpPost] public ActionResult Create(MyModel Model) { ..
Model.List
为null?
该列表在GET
上填充正常。 但是,在POST
(此特定View是一个表单) Model.List
为null。 我尝试过使用HiddenFor
助手,但还没有成功。
任何建议/答案都表示赞赏。 谢谢。
您需要使用for
循环而不是foreach
循环来使数据绑定与集合一起正常工作。
因此,不要执行foreach循环,而是将代码更改为以下内容:
@for (var i = 0; i < Model.List.Count(); i++) { @Html.HiddenFor(model => Model.List[i].UserId) @Html.HiddenFor(model => Model.List[i].Name) @Html.HiddenFor(model => Model.List[i].Age) @Html.CheckBoxFor(model => Model.List[i].IsChecked, new { id = Model.List[i].UserId }) }
这使得ModelBinder可以跟踪您尝试绑定的集合中项目的索引。
如果您在完成此操作时查看生成的HTML,您会注意到生成的输入控件将如下所示:
这使模型绑定器能够知道列表中绑定的项目。
上述就是C#学习教程:使用Razor在POST上使用Model.List为null分享的全部内容,如果对大家有所用处且需要了解更多关于C#学习教程,希望大家多多关注—计算机技术网(www.ctvol.com)!
本文来自网络收集,不代表计算机技术网立场,如涉及侵权请联系管理员删除。
ctvol管理联系方式QQ:251552304
本文章地址:https://www.ctvol.com/cdevelopment/1012881.html