说我有以下型号:
public class Person
{
public string Name { get; set; }
public int Age { get; set; }
}
public class Town
{
public string Name { get; set; }
public IEnumerable<Person> People { get; set; }
}
然后,在我的Razor视图中,我有这个:
@model Town
@using(Html.BeginForm())
{
<table>
@foreach(var person in Model.People)
{
<tr>
<td>@Html.TextBoxFor(m => person.Name)</td>
<td>@Html.TextBoxFor(m => person.Age)</td>
</tr>
}
<table>
<input type="submit" />
}
然后,我有一个POST的动作,如下所示:
[HttpPost]
public ActionResult Index(Town theTown)
{
//....
}
发布时,IEnumerable<Person>
没有发现。如果我在Fiddler中查看它,该集合只发布一次,并且不会枚举该集合,所以我得到:
People.Name = "whatever"
People.Age = 99
但是,如果我将人员更改为IList
并使用for循环而不是foreach ...
@for(var i = 0;i < Model.People.Count;i++)
{
<tr>
<td>@Html.TextBoxFor(m => Model.People[i].Name)</td>
<td>@Html.TextBoxFor(m => Model.People[i].Age)</td>
</tr>
}
有效。难道我做错了什么?我错过了什么?
答案 0 :(得分:61)
问题不在于IEnumerable
或IList
,而是在视图中呈现集合的方式。
@for(var i = 0;i < Model.People.Count;i++)
{
<tr>
<td>@Html.TextBoxFor(m => Model.People[i].Name)</td>
<td>@Html.TextBoxFor(m => Model.People[i].Age)</td>
</tr>
}
观察每个列表项,您附加一个连续索引,使模型绑定器能够发挥其魔力
答案 1 :(得分:0)
你错过的只是放置var而不是模型本身(People),如下所示
<table>
@foreach(People person in Model.People)
{
<tr>
<td>@Html.TextBoxFor(m => person.Name)</td>
<td>@Html.TextBoxFor(m => person.Age)</td>
</tr>
}
<table>
<input type="submit" />