1

我有一个由 List 模型组成的表单。当表单提交回操作方法时,列表为空。我该如何设置?

public ActionResult PendingRenewals()
{
    //get list elements
    var customers = get customer that match our criteria;

    //Build list
    List<string[]> renewals = new List<string[]>();
    foreach(var item in customers)
    {
        renewals.Add(new string[] {item.name, item.id, item.PO });
    }
    return View(renewals);
}

看法

   @model List<string[]>
   @using (Html.BeginForm()
   {
       <input type="submit" value="Save"/>
       <table>
           @foreach (var item in Model)
           {
               <tr>
                   <td>item[0]</td>
                   <td>item[1]</td>
                   <td>@Html.EditorFor(model => item[2])</td>
                   </td>
               </tr>
           }
    </table>
}

返回控制器

[HttpPost]
public ActionResult PendingRenewals(List<string[]> renewal, string EntityId)
{
    //renewals is always null
    return PendingRenewals();
}

解决方案

使用 FortyTwo 的想法,我使用了 string[][] 作为模型,所以视图看起来像这样 (model[i][0]) 和 model[i][1] 是我需要传递回控制器的字段):

            @model string[][]
            @for (int i = 0; i < Model.Length; i++ )
            {
            <tr>
                <td>@Model[i][2]</td>
                <td>@Model[i][3]</td>
                <td>@Model[i][4]</td>
                <td>@Model[i][5]</td>
                <td>@Html.HiddenFor(model => model[i][0]) @Html.TextBoxFor(model => Model[i][1])</td>
            </tr>
        }
4

2 回答 2

1

您需要使用老式的 for 循环。这样,索引器用于遵守 mvc 模型绑定器所需的命名约定。

@for (int i = 0; i < Model.Count; i++)
       {
           <tr>
               <td>Model[i].item[0]</td>
               <td>Model[i].item[1]</td>
               <td>@Html.EditorFor(model => model[i].item[2])</td>
               </td>
           </tr>
       }
于 2013-02-14T15:38:15.377 回答
0

FortyTwo 是正确的,您需要使用索引来获取模型绑定器的正确表单数据,但我认为即使您这样做,模型绑定器也无法理解您从表单发回的数据。

无论哪种方式,而不是使用字符串数组列表,更好的方法是创建一个“客户”类型,将您的模型设置为客户列表,并为客户类型的属性创建一个编辑器。

于 2013-02-14T16:09:27.253 回答