Pet*_*son 4 c# asp.net-mvc entity-framework razor asp.net-mvc-4
我是 MVC 的新手,在理解这一点时遇到了一些困难。
为简单起见,我有一个“Person”对象,该对象有一个名为“EmailaddressList”的 IEnumerable 属性。
我已经通过 Visual Studio 2012 生成了一个编辑页面。主要对象属性是在编辑页面上生成的,其中包含 Name 和 LastName 等文本框。
但是,在我看来,IEnumerable 子对象列表中的电子邮件地址列表不是自动生成的。没关系,我已经使用每种类型的电子邮件地址的选项卡手工编写了该代码。
到现在为止还挺好。
问题: 当我在 HTTP-Post 方法中收到模型(person 对象)时,EmailAddressList 为空。为什么会这样,我把它发送到视图时它不为空。列出电子邮件地址的选项卡在局部视图中。任何人都可以给我一些提示,我在这里缺少什么吗?*
查看代码
<div id="tabs">
<ul>
@foreach (var item in Model.EmailAddressList)
{
<li><a href="#@item.AddressType">@Html.Label(item.AddressType)</a></li>
}
</ul>
@foreach (var item in Model.EmailAddressList)
{
<div id="@item.AddressType">
<p>
@Html.TextBoxFor(s => item.EmailAddress, new { @class = "input-xxlarge" })
</p>
</div>
}
</div>
Run Code Online (Sandbox Code Playgroud)
控制器(接收方法) 这里 person.EmailAddressList 为空
[HttpPost]
public ActionResult Create(Person person)
{
if (ModelState.IsValid)
{
personRepository.InsertOrUpdate(person);
personRepository.Save();
return RedirectToAction("Index");
}
else
{
return View();
}
}
Run Code Online (Sandbox Code Playgroud)
那是因为为了正确索引您的字段(因此模型绑定器可以完成它的工作),您必须使用for
循环。
首先,将 your 更改IEnumerable
为 a List
(以便我们可以在视图中使用索引器)。
然后将您更改foreach
为以下for
循环:
@for (int i = 0; i < Model.EmailAddressList.Count; i++)
{
<div id="@Model.EmailAddressList[i].AddressType">
<p>
@Html.TextBoxFor(m => m.EmailAddressList[i].EmailAddress, new { @class = "input-xxlarge" })
</p>
</div>
}
Run Code Online (Sandbox Code Playgroud)
归档时间: |
|
查看次数: |
2761 次 |
最近记录: |