【问题标题】:Binding List of Lists in MVC 2.0MVC 2.0 中列表的绑定列表
【发布时间】:2019-08-15 10:24:11
【问题描述】:

我需要处理表单中的List<List<T>>,但找不到如何继续使用旧版本的 MVC 和 .NET。

我确实尝试了以下方法:

型号:

public class MyModel
{
    public List<List<Item>> ListA { get; set; }
}

public class Item
{
    public string Name { get; set; }
    public string Spec { get; set; }
    public string Type { get; set; }
    public string Field1 { get; set; }
    public string Field2 { get; set; }
    public string Field3 { get; set; }
    public string Field4 { get; set; }
    public string Field5 { get; set; }
}

查看:

<%@ Control Language="C#" Inherits="System.Web.Mvc.ViewUserControl<MyModel>" %>

<% for(int i = 0; i < Model.ListA.Count; i++) { %>
    <fieldset>
        <div>
            <input disabled="disabled" value="Name" />
            <input disabled="disabled" value="Spec" />
            <input disabled="disabled" value="Type" />
            <input disabled="disabled" value="Field 1" />
            <input disabled="disabled" value="Field 2" />
            <input disabled="disabled" value="Field 3" />
            <input disabled="disabled" value="Field 4" />
            <input disabled="disabled" value="Field 5" />
        </div>
        <% for(int j = 0; j < Model.ListA[i].Count; j++) { %>
            <div>
                <%= Html.EditorFor(m => m.ListA[i][j].Name)%>
                <%= Html.EditorFor(m => m.ListA[i][j].Spec)%>
                <%= Html.EditorFor(m => m.ListA[i][j].Type)%>
                <%= Html.EditorFor(m => m.ListA[i][j].Field1)%>
                <%= Html.EditorFor(m => m.ListA[i][j].Field2)%>
                <%= Html.EditorFor(m => m.ListA[i][j].Field3)%>
                <%= Html.EditorFor(m => m.ListA[i][j].Field4)%>
                <%= Html.EditorFor(m => m.ListA[i][j].Field5)%>
            </div>
        <% } %>
    </div>
<% } %>

控制器:

[HttpGet]
public ActionResult MyAction(int Id)
{
    // MyModel modObj = MyService.GetModelById(Id);
    MyModel modObj = new MyModel
    {
        ListA = new List<List<Item>>
        {
            new List<Item>
            {
                new Item { Name = "0 - 0" },
                new Item { Name = "0 - 1" },
                new Item { Name = "0 - 2" }
            },
            new List<Item>
            {
                new Item { Name = "1 - 0" },
                new Item { Name = "1 - 1" },
                new Item { Name = "1 - 2" }
            }
        }
    }

    return View(modObj);
}

[HttpPost]
public ActionResult MyAction(MyModel model)
{
    // anything
    return null;
}

我的问题是,目前,即使我可以正确看到每个项目的编辑器(这里是三个项目的两个列表),当我发回它时,我也只能看到控制器中三个项目的第一个列表。

我也尝试将模型更改为:

public class MyModel
{
   public List<ItemList> ListA { get; set; }
}

public class ItemList
{
    public string PropId { get; set; }
    public List<Item> ListB { get; set; }
}

public class Item
{
    public string Name { get; set; }
    public string Spec { get; set; }
    public string Type { get; set; }
    public string Field1 { get; set; }
    public string Field2 { get; set; }
    public string Field3 { get; set; }
    public string Field4 { get; set; }
    public string Field5 { get; set; }
}

并相应地更改了我的视图和控制器,但我仍然得到相同的结果:第一个列表级别在我发回时只包含一个列表 - 我只得到"0 - 0""0 - 1" &"0 - 2"在控制器的POST方法中设置断点时。

我在这里不知道。

编辑:要回答 Jonny 的问题,List&lt;ItemList&gt; 是这样的:

<fieldset>
    <div>
        <input disabled="disabled" value="Name" />
        <input disabled="disabled" value="Spec" />
        <input disabled="disabled" value="Type" />
        <input disabled="disabled" value="Field 1" />
        <input disabled="disabled" value="Field 2" />
        <input disabled="disabled" value="Field 3" />
        <input disabled="disabled" value="Field 4" />
        <input disabled="disabled" value="Field 5" />
    </div>
    <div>
        <input name="ListA[0].ListB[0].Name" id="ListA_0__ListB_0__Name" type="text" value="0 - 0"></input>
        <input name="ListA[0].ListB[0].Spec" id="ListA_0__ListB_0__Spec" type="text"></input>
        <input name="ListA[0].ListB[0].Type" id="ListA_0__ListB_0__Type" type="text"></input>
        <input name="ListA[0].ListB[0].Field1" id="ListA_0__ListB_0__Field1" type="text"></input>
        <input name="ListA[0].ListB[0].Field2" id="ListA_0__ListB_0__Field2" type="text"></input>
        <input name="ListA[0].ListB[0].Field3" id="ListA_0__ListB_0__Field3" type="text"></input>
        <input name="ListA[0].ListB[0].Field4" id="ListA_0__ListB_0__Field4" type="text"></input>
        <input name="ListA[0].ListB[0].Field5" id="ListA_0__ListB_0__Field5" type="text"></input>
    </div>
    <div>
        <input name="ListA[0].ListB[1].Name" id="ListA_0__ListB_1__Name" type="text" value="0 - 1"></input>
        <input name="ListA[0].ListB[1].Spec" id="ListA_0__ListB_1__Spec" type="text"></input>
        <input name="ListA[0].ListB[1].Type" id="ListA_0__ListB_1__Type" type="text"></input>
        <input name="ListA[0].ListB[1].Field1" id="ListA_0__ListB_1__Field1" type="text"></input>
        <input name="ListA[0].ListB[1].Field2" id="ListA_0__ListB_1__Field2" type="text"></input>
        <input name="ListA[0].ListB[1].Field3" id="ListA_0__ListB_1__Field3" type="text"></input>
        <input name="ListA[0].ListB[1].Field4" id="ListA_0__ListB_1__Field4" type="text"></input>
        <input name="ListA[0].ListB[1].Field5" id="ListA_0__ListB_1__Field5" type="text"></input>
    </div>
    <div>
        <input name="ListA[0].ListB[2].Name" id="ListA_0__ListB_2__Name" type="text" value="0 - 2"></input>
        <input name="ListA[0].ListB[2].Spec" id="ListA_0__ListB_2__Spec" type="text"></input>
        <input name="ListA[0].ListB[2].Type" id="ListA_0__ListB_2__Type" type="text"></input>
        <input name="ListA[0].ListB[2].Field1" id="ListA_0__ListB_2__Field1" type="text"></input>
        <input name="ListA[0].ListB[2].Field2" id="ListA_0__ListB_2__Field2" type="text"></input>
        <input name="ListA[0].ListB[2].Field3" id="ListA_0__ListB_2__Field3" type="text"></input>
        <input name="ListA[0].ListB[2].Field4" id="ListA_0__ListB_2__Field4" type="text"></input>
        <input name="ListA[0].ListB[2].Field5" id="ListA_0__ListB_2__Field5" type="text"></input>
    </div>
</fieldset>
<fieldset>
    <div>
        <input disabled="disabled" value="Name" />
        <input disabled="disabled" value="Spec" />
        <input disabled="disabled" value="Type" />
        <input disabled="disabled" value="Field 1" />
        <input disabled="disabled" value="Field 2" />
        <input disabled="disabled" value="Field 3" />
        <input disabled="disabled" value="Field 4" />
        <input disabled="disabled" value="Field 5" />
    </div>
    <div>
        <input name="ListA[1].ListB[0].Name" id="ListA_1__ListB_0__Name" type="text" value="1 - 0"></input>
        <input name="ListA[1].ListB[0].Spec" id="ListA_1__ListB_0__Spec" type="text"></input>
        <input name="ListA[1].ListB[0].Type" id="ListA_1__ListB_0__Type" type="text"></input>
        <input name="ListA[1].ListB[0].Field1" id="ListA_1__ListB_0__Field1" type="text"></input>
        <input name="ListA[1].ListB[0].Field2" id="ListA_1__ListB_0__Field2" type="text"></input>
        <input name="ListA[1].ListB[0].Field3" id="ListA_1__ListB_0__Field3" type="text"></input>
        <input name="ListA[1].ListB[0].Field4" id="ListA_1__ListB_0__Field4" type="text"></input>
        <input name="ListA[1].ListB[0].Field5" id="ListA_1__ListB_0__Field5" type="text"></input>
    </div>
    <div>
        <input name="ListA[1].ListB[1].Name" id="ListA_1__ListB_1__Name" type="text" value="1 - 1"></input>
        <input name="ListA[1].ListB[1].Spec" id="ListA_1__ListB_1__Spec" type="text"></input>
        <input name="ListA[1].ListB[1].Type" id="ListA_1__ListB_1__Type" type="text"></input>
        <input name="ListA[1].ListB[1].Field1" id="ListA_1__ListB_1__Field1" type="text"></input>
        <input name="ListA[1].ListB[1].Field2" id="ListA_1__ListB_1__Field2" type="text"></input>
        <input name="ListA[1].ListB[1].Field3" id="ListA_1__ListB_1__Field3" type="text"></input>
        <input name="ListA[1].ListB[1].Field4" id="ListA_1__ListB_1__Field4" type="text"></input>
        <input name="ListA[1].ListB[1].Field5" id="ListA_1__ListB_1__Field5" type="text"></input>
    </div>
    <div>
        <input name="ListA[1].ListB[2].Name" id="ListA_1__ListB_2__Name" type="text" value="1 - 2"></input>
        <input name="ListA[1].ListB[2].Spec" id="ListA_1__ListB_2__Spec" type="text"></input>
        <input name="ListA[1].ListB[2].Type" id="ListA_1__ListB_2__Type" type="text"></input>
        <input name="ListA[1].ListB[2].Field1" id="ListA_1__ListB_2__Field1" type="text"></input>
        <input name="ListA[1].ListB[2].Field2" id="ListA_1__ListB_2__Field2" type="text"></input>
        <input name="ListA[1].ListB[2].Field3" id="ListA_1__ListB_2__Field3" type="text"></input>
        <input name="ListA[1].ListB[2].Field4" id="ListA_1__ListB_2__Field4" type="text"></input>
        <input name="ListA[1].ListB[2].Field5" id="ListA_1__ListB_2__Field5" type="text"></input>
    </div>
</fieldset>

List&lt;List&lt;Item&gt;&gt;:

<fieldset>
    <div>
        <input disabled="disabled" value="Name" />
        <input disabled="disabled" value="Spec" />
        <input disabled="disabled" value="Type" />
        <input disabled="disabled" value="Field 1" />
        <input disabled="disabled" value="Field 2" />
        <input disabled="disabled" value="Field 3" />
        <input disabled="disabled" value="Field 4" />
        <input disabled="disabled" value="Field 5" />
    </div>
    <div>
        <input name="ListA[0][0].Name" id="ListA_0__0__Name" type="text" value="0 - 0"></input>
        <input name="ListA[0][0].Spec" id="ListA_0__0__Spec" type="text"></input>
        <input name="ListA[0][0].Type" id="ListA_0__0__Type" type="text"></input>
        <input name="ListA[0][0].Field1" id="ListA_0__0__Field1" type="text"></input>
        <input name="ListA[0][0].Field2" id="ListA_0__0__Field2" type="text"></input>
        <input name="ListA[0][0].Field3" id="ListA_0__0__Field3" type="text"></input>
        <input name="ListA[0][0].Field4" id="ListA_0__0__Field4" type="text"></input>
        <input name="ListA[0][0].Field5" id="ListA_0__0__Field5" type="text"></input>
    </div>
    <div>
        <input name="ListA[0][1].Name" id="ListA_0__1__Name" type="text" value="0 - 1"></input>
        <input name="ListA[0][1].Spec" id="ListA_0__1__Spec" type="text"></input>
        <input name="ListA[0][1].Type" id="ListA_0__1__Type" type="text"></input>
        <input name="ListA[0][1].Field1" id="ListA_0__1__Field1" type="text"></input>
        <input name="ListA[0][1].Field2" id="ListA_0__1__Field2" type="text"></input>
        <input name="ListA[0][1].Field3" id="ListA_0__1__Field3" type="text"></input>
        <input name="ListA[0][1].Field4" id="ListA_0__1__Field4" type="text"></input>
        <input name="ListA[0][1].Field5" id="ListA_0__1__Field5" type="text"></input>
    </div>
    <div>
        <input name="ListA[0][2].Name" id="ListA_0__2__Name" type="text" value="0 - 2"></input>
        <input name="ListA[0][2].Spec" id="ListA_0__2__Spec" type="text"></input>
        <input name="ListA[0][2].Type" id="ListA_0__2__Type" type="text"></input>
        <input name="ListA[0][2].Field1" id="ListA_0__2__Field1" type="text"></input>
        <input name="ListA[0][2].Field2" id="ListA_0__2__Field2" type="text"></input>
        <input name="ListA[0][2].Field3" id="ListA_0__2__Field3" type="text"></input>
        <input name="ListA[0][2].Field4" id="ListA_0__2__Field4" type="text"></input>
        <input name="ListA[0][2].Field5" id="ListA_0__2__Field5" type="text"></input>
    </div>
</fieldset>
<fieldset>
    <div>
        <input disabled="disabled" value="Name" />
        <input disabled="disabled" value="Spec" />
        <input disabled="disabled" value="Type" />
        <input disabled="disabled" value="Field 1" />
        <input disabled="disabled" value="Field 2" />
        <input disabled="disabled" value="Field 3" />
        <input disabled="disabled" value="Field 4" />
        <input disabled="disabled" value="Field 5" />
    </div>
    <div>
        <input name="ListA[1][0].Name" id="ListA_1__0__Name" type="text" value="1 - 0"></input>
        <input name="ListA[1][0].Spec" id="ListA_1__0__Spec" type="text"></input>
        <input name="ListA[1][0].Type" id="ListA_1__0__Type" type="text"></input>
        <input name="ListA[1][0].Field1" id="ListA_1__0__Field1" type="text"></input>
        <input name="ListA[1][0].Field2" id="ListA_1__0__Field2" type="text"></input>
        <input name="ListA[1][0].Field3" id="ListA_1__0__Field3" type="text"></input>
        <input name="ListA[1][0].Field4" id="ListA_1__0__Field4" type="text"></input>
        <input name="ListA[1][0].Field5" id="ListA_1__0__Field5" type="text"></input>
    </div>
    <div>
        <input name="ListA[1][1].Name" id="ListA_1__1__Name" type="text" value="1 - 1"></input>
        <input name="ListA[1][1].Spec" id="ListA_1__1__Spec" type="text"></input>
        <input name="ListA[1][1].Type" id="ListA_1__1__Type" type="text"></input>
        <input name="ListA[1][1].Field1" id="ListA_1__1__Field1" type="text"></input>
        <input name="ListA[1][1].Field2" id="ListA_1__1__Field2" type="text"></input>
        <input name="ListA[1][1].Field3" id="ListA_1__1__Field3" type="text"></input>
        <input name="ListA[1][1].Field4" id="ListA_1__1__Field4" type="text"></input>
        <input name="ListA[1][1].Field5" id="ListA_1__1__Field5" type="text"></input>
    </div>
    <div>
        <input name="ListA[1][2].Name" id="ListA_1__2__Name" type="text" value="1 - 2"></input>
        <input name="ListA[1][2].Spec" id="ListA_1__2__Spec" type="text"></input>
        <input name="ListA[1][2].Type" id="ListA_1__2__Type" type="text"></input>
        <input name="ListA[1][2].Field1" id="ListA_1__2__Field1" type="text"></input>
        <input name="ListA[1][2].Field2" id="ListA_1__2__Field2" type="text"></input>
        <input name="ListA[1][2].Field3" id="ListA_1__2__Field3" type="text"></input>
        <input name="ListA[1][2].Field4" id="ListA_1__2__Field4" type="text"></input>
        <input name="ListA[1][2].Field5" id="ListA_1__2__Field5" type="text"></input>
    </div>
</fieldset>

编辑 2

我终于成功了,逐行重写相同的代码...
所以我不知道为什么它以前不起作用。

【问题讨论】:

  • 本地机器上没有 MVC 4(使用 ASPX)和 5(使用 Razor)的复制,也尝试使用 this fiddle 并且在回发时成功检索了两个列表。回发期间第一个List 级别中包含哪个列表(第一个值为0 或1)?
  • @TetsuyaYamamoto 使用"0 - x" 的那些,我知道它应该适用于最近的框架,这就是为什么我特别说我正在使用一个 reaaaally 旧框架
  • 生成的 html 输入是什么样的?
  • @Jonny 我编辑了我的问题来回答你的问题

标签: c# asp.net-mvc-2 nested-lists


【解决方案1】:

//查看

@model WebApplication1.Controllers.MyModel

@{
    Layout = null;
    var model = Model;
}

<!DOCTYPE html>

<html>
<head>
    <meta name="viewport" content="width=device-width" />
    <title>Index1</title>
</head>
<body>
@using (Html.BeginForm())
{
    @Html.AntiForgeryToken()
    {
    for (int i = 0; i < Model.ListA.Count; i++)
    {
    <div>
         @for (int j = 0; j < Model.ListA[i].Count; j++)
         {
        <div>
             @Html.EditorFor(m => m.ListA[i][j].Property1)
        </div>
         } 
    </div>
        }
        <input type="submit" value="Create" class="btn btn-default" />
    }
}
    <p>

        @Html.ActionLink("Back to List", "Index")
    </p>
</body>
</html>

【讨论】:

  • 你好@rami 你能解释一下你的答案吗
  • @using (Html.BeginForm()){} 基本上是创建一个表单。其中的提交按钮将提交表单并将字段转换为json,该实习生将由控制器中的HTTP post方法使用具有正确数据的模型。
  • 你能编辑你的答案,评论你的代码并解释你做了什么。这种形式的回答没有帮助。
  • 您好,欢迎来到 StackOverflow。虽然这在现代框架中确实可以按预期工作,但我看不出它与我当前的代码有何不同(除了当我特别要求 .NET Framework 4、MVC 2 时您使用 Razor 的事实,因此ASPX)。如果你能解释是什么让你认为它回答了我的问题,我真的很想:)
猜你喜欢
  • 2015-05-18
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2011-05-19
  • 2016-09-27
  • 1970-01-01
相关资源
最近更新 更多