MVC 2.0中的列表绑定列表

时间:2019-03-25 07:58:12

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

我需要以一种格式处理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; }
}

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

我在这里没主意。

编辑:要回答乔尼的问题,"0 - 2"的样子如下:

List<ItemList>

并带有<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<List<Item>>


编辑2

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

1 个答案:

答案 0 :(得分:0)

//查看

@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>