0

我正在对表单中的对象集合使用增量排序。除非我需要使用 DropDownListFor,否则一切正常。很多关于绑定下拉列表和选择正确值的问题,在我的情况下工作正常。但是,我不清楚我的控制器中的 HttpPost 操作应该有什么。这是我的代码:

模型

public class WorkRequestList
{
    public WorkRequest[] Requests { get; set; }
    public Vehicle[] Vehicles { get; set; }       
}

看法

 <% using (Html.BeginForm()) {%>
     <% for (var i = 0; i < Model.Requests.Count(); i++) { %>
        <%=Html.DropDownListFor(x => x.Requests[i].AssignedTo,new SelectList(Model.Vehicles,"Id","Name",Model.Requests[i].AssignedTo.Id)) %>
      <%}%>
 <%=Html.SubmitButton("TopSubmit","Submit") %>
<%}%>

发布动作

[HttpPost]
public ActionResult Schedule(WorkRequestList form)
{
      //what goes here?
}

下拉列表填充得很好,它们被预先选择得很好。但在回发 form.Requests.AssignedTo 为空。我假设车辆 ID 被发布回某处,但是我如何在不通过Request魔术字符串循环的情况下实现这一点:

var id = Request["Requests[" + i + "].AssignedTo"];
4

1 回答 1

1

这是另一种方法,因为如果没有明确的模型绑定器,我也无法绑定子对象:

为您的响应定义一个新类:

public class WorkRequestResponse 
{
    public int AssignedTo { get; set; }
}

在页面上更改如下:(我将请求更改为 WorkRequest)

<% for (var i = 0; i < Model.WorkRequest.Count(); i++)
       { %>
    <%=Html.DropDownListFor(x => x.WorkRequest[i].AssignedTo, new SelectList(Model.Vehicles, "Id", "Name", Model.WorkRequest[i].AssignedTo.Id))%>
    <%}%>

在您的控制器上绑定如下:

public ActionResult Index([Bind(Prefix = "WorkRequest")]List<WorkRequestResponse> AssignedTo)
{
    // AssignedTo is now populated
    WorkRequestList.WorkRequests = magic_assign_function(AssignedTo); 
    // manual model validation etc....
}

我很想看看是否有更直接的路线,因为这也困扰着我。

于 2010-03-31T02:12:33.243 回答