假设我有以下模型:
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
但是,如果我将People更改为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>
}
它的工作原理。我做错了什么吗?我错过了什么?
问题不在于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>
}
请注意,对于每个列表项,您都添加了一个连续索引,使模型绑定器能够发挥其魔力
好的阅读
您错过的只是在
下面放置var而不是Model本身(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" />