ASP.NET MVC:如何绑定List <t>类型的属性?</t>

时间:2010-11-12 10:41:18

标签: asp.net-mvc model-binding

假设我有波纹管模型

public class UserInformation
{
  public List<UserInRole> RolesForUser { get; set; }      
  //Other properties omitted...
}

public class UserInRole
{
  public string RoleName { get; set; }
  public bool InRole { get; set; }
}

在我的页面上,我有类似

的内容
<%using(Html.BeginForm()){%>
  .../...
  <%for(int i =0; i<Model.InRoles.Cout; i++%>
  <p><%: Html.CheckBox(Model.Roles[i].RoleName, Model.Roles[i].InRole)%></p>
<%}%>

我们的想法是能够选中/取消选中该复选框,以便在将表单发布到操作时,通过从每个角色添加/删除用户来适当地执行操作。

问题是当表单发布到action方法时,Roles属性(列表UserInRole对象)不反映用户所做的更改。 ModelBinder适用于所有其他属性,但'角色属性'

我想知道我该怎么做。我怀疑给复选框的名称/ ID是不合适的。但是,我只是堆叠。也许我应该采用不同的方式。

感谢您的帮助

2 个答案:

答案 0 :(得分:2)

你应该在model binding to a list看到Phil Haack的帖子。 基本上你需要的只是提交一堆表格字段,每个字段具有相同的名称。

<%@ Page Inherits="ViewPage<UserInformation>" %>

<% for (int i = 0; i < 3; i++) { %>

  <%: Html.EditorFor(m => m.RolesForUser[i].RoleName) %>
  <%: Html.EditorFor(m => m.RolesForUser[i].InRole) %>

<% } %>

答案 1 :(得分:1)

我认为问题在于您提交表单数据的方式。要使模型绑定工作,它需要键名及其关联值。以下代码应基于您的代码正确绑定:

<%using(Html.BeginForm()){%>
  .../...
  <%for(int i =0; i<Model.RolesForUser.Count; i++%>
  <p>
     <%: Html.Hidden("UserInformation.RolesForUser[" + i + "].RoleName", Model.RolesForUser[i].RoleName) %>
     <%: Html.CheckBox("UserInformation.RolesForUser[" + i + "].InRole", Model.RolesForUser[i].InRole) %>
     <%: Model.RolesForUser[i].RoleName %>
  </p>
<%}%>