我有这些DTO的
public class Header
{
public int HeaderId{get;set;}
public int Description{get;set;}
public List<HeaderItem> HeaderItems{get;set;}
}
public class HeaderItem
{
public int HeaderItemId{get;set;}
public string DetailDescription{ get; set; }
public bool Selected{ get; set; }
}
我有这个控制器
[HttpPost]
public ActionResult PostMethod(Header dto)
{
...
}
和这个html
@using (Html.BeginForm("PostMethod", "Controller", FormMethod.Post, new { id = "form" }))
{
@Html.TextBoxFor(x => x.Description)
var grid = new WebGrid(Model.HeaderItems);
}
@grid.GetHtml(tableStyle: "grid",
htmlAttributes: new { id = "grid" },
columns: grid.Columns(
grid.Column("Selected", "Seç", format: (item) => Html.CheckBox(String.Format("Selected_{0}", (int)item.HeaderItemId), false)),
grid.Column("HeaderItemId", "", format: (item) => Html.Hidden("HeaderItemId")),
grid.Column("DetailDescription", "Description")
)
}
因此,这个网格有一个复选框和一个HiddenField,它保存每行的HeaderItemId值。
我想发布我的表单并填充Header类的属性HeaderItems。
我怎样才能达到这个解决方案?
答案 0 :(得分:5)
我怎样才能达到这个解决方案?
像这样:
columns: grid.Columns(
grid.Column(
"Selected",
"Seç",
format:
@<text>
@{ var index = Guid.NewGuid().ToString(); }
@Html.Hidden("HeaderItems.Index", index)
@Html.Hidden("HeaderItems[" + index + "].HeaderItemId", (int)item.HeaderItemId)
@Html.CheckBox("HeaderItems[" + index + "].Selected", (bool)item.Selected)
</text>
),
grid.Column("HeaderItemId")
grid.Column("DetailDescription", "Description")
)
答案 1 :(得分:0)
尝试更改Html.CheckBox
的{{1}}和Html.CheckBoxFor
Html.Hidden
的相同内容。
这将是:
Html.HiddenFor
我没有考虑过它......