我需要以一种格式处理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>>
我终于设法做到了,逐行重写了相同的代码...
所以我不知道为什么以前不起作用。
答案 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>