我有一个正在从模型中正确填充的视图。以下是视图的缩写:
@model PickardOrdering.Models.ExhibitionItemModel
@foreach (var item in Model.Items)
{
<tr>
<td>@Html.DisplayFor(modelItem => item.Code)</td>
<td>@Html.DisplayFor(modelItem => item.Description)</td>
<td>@Html.CheckBoxFor(modelItem => item.AdditionalItem.Value, new { @disabled = "disabled" })</td>
<td>@Html.CheckBoxFor(modelItem => item.IsItemSelected.Value)</td>
<td>£ @Html.EditorFor(modelItem => item.ItemPrice)</td>
</tr>
}
<input type="submit" value="Save Items" />
当我将数据发布回控制器时,exhibitionitemmodel为null:
[HttpPost, ActionName("CreateExhibitionItems")]
public ActionResult CreateExhibitionItems(ExhibitionItemModel exhibitionitemmodel)
{
decimal decPrice;
if (ModelState.IsValid)
{
List<tblExhibitionItem> lstExhibitionItem = new List<tblExhibitionItem>();
IEnumerable<ItemWrapper> lstItemWrapper = from objExhibitionItemModel in exhibitionitemmodel.Items
select objExhibitionItemModel;
以下是使用的模型类:
namespace PickardOrdering.Models
{
public class ItemWrapper : tblItem
{
public decimal ItemPrice { get; set; }
public bool? IsItemSelected { get; set; }
}
public class ExhibitionItemModel
{
public IEnumerable<ItemWrapper> Items { get; set; }
public tblExhibition Exhibition { get; set; }
public IEnumerable<tblExhibitionItem> ExhibitionItems { get; set; }
}
}
为什么模型数据为空的任何想法?
答案 0 :(得分:1)
确保在模型中使用的每个类上都有一个公共无参数构造函数,包括它们使用的枚举和类。
另外,在构造函数中实例化包含的类。模型绑定器需要填充对象的实例。示例如下。对模型使用的所有类执行此操作。
public class ExhibitionItemModel
{
public ExhibitionItemModel(){
Exhibition = new tblExhibition();
ExhibitionItems = new List<tblExhibitonItem>();
Items = new List<ItemWrapper>();
}
public IEnumerable<ItemWrapper> Items { get; set; }
public tblExhibition Exhibition { get; set; }
public IEnumerable<tblExhibitionItem> ExhibitionItems { get; set; }
}
此外,在您的视图中,使用索引而不是foreach循环迭代您的项目。这样,视图将生成包含模型绑定器可以理解的索引的名称。
答案 1 :(得分:1)
通过模型绑定让生活更轻松,我会
建议为ItemWrapper
课程制作一个EditorTemplate。
// Views/<WhateverYourControllerIsCalled>/EditorTemplates/ItemWrapper.cshtml
@model PickardOrdering.Models.ItemWrapper
<tr>
<td>@Html.DisplayFor(m => m.Code)</td>
<td>@Html.DisplayFor(m => m.Description)</td>
<td>@Html.CheckBoxFor(m => m.AdditionalItem.Value, new { @disabled = "disabled" })</td>
<td>@Html.CheckBoxFor(m => m.IsItemSelected.Value)</td>
<td> @Html.EditorFor(m => m.ItemPrice)</td>
</tr>
您的主要.cshtml变为:
@model PickardOrdering.Models.ExhibitionItemModel
@using (Html.BeginForm("CreateExhibitionItems", "Home", FormMethod.Post))
{
<table>
@Html.EditorFor(m => m.Items)
</table>
<input type="submit" value="Save Items" />
}
在Items
集合上使用EditorFor将呈现
html,默认绑定器期望的格式
绑定到列表。您可以使用手动渲染html
一个索引和一个for循环,如果你想更好地控制它,
但这种方式可以帮到你。
作为我觉得在这些情况下有用的一般提示,
在动作方法中添加FormCollection
参数
收到帖子,并在期间检查此参数
调试。这有助于查看发布的数据
从形式,从那里你可以找出它的原因
在模型绑定期间没有绑定。
答案 2 :(得分:0)
您的CSHTML
中是否有任何表单可以使用此article
您必须使用此代码
@using (Html.BeginForm("CreateExhibitionItems", "controllerName", FormMethod.Post))
{ @foreach (var item in Model.Items)
{
<tr>
<td>@Html.DisplayFor(modelItem => item.Code)</td>
<td>@Html.DisplayFor(modelItem => item.Description)</td>
<td>@Html.CheckBoxFor(modelItem => item.AdditionalItem.Value, new { @disabled = "disabled" })</td>
<td>@Html.CheckBoxFor(modelItem => item.IsItemSelected.Value)</td>
<td>£ @Html.EditorFor(modelItem => item.ItemPrice)</td>
</tr>
}
<input type="submit" value="Save Items" />}