提交后 IEnumerable 属性为空

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)

mat*_*mmo 6

那是因为为了正确索引您的字段(因此模型绑定器可以完成它的工作),您必须使用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)