10

我想从一个列表中动态创建 DropDownLists,它提供了 SelectList 和一个用于保存选择的字段。

public class ViewModel
{
    public List<Material_Select> materialSelect { get; set; }
}

public class Material_Select
{
    public SelectList selectList { get; set; }
    public int MaterialId { get; set; }
}

在视图中,我想遍历 materialSelect List 并动态创建 DropDownLists。

像这样的东西:

int count = 0;
foreach (var item in Model.materialSelect)
{
    count++;
    <div class="editor-label">
        @Html.LabelFor(model => model.materialSelect)
    </div>
    <div class="editor-field">
        @Html.DropDownListFor(item.MaterialId, item.selectList)
    </div>       
}

在 HttpPost ActionResult 我需要获取选定的值。有谁知道如何解决这个问题?

4

2 回答 2

9

您可能应该使用EditorTemplates。这些允许你做你所描述的事情。如果您在 ~/Views/Shared/EditorTemplates/Material_Select.cshtml 中创建一个强类型的局部视图(视图必须与模型命名相同),如下所示:

@model Material_Select

<div class="editor-label">
    @Html.LabelFor(m => m.MaterialId)
</div>
<div class="editor-field">
    @Html.DropDownListFor(m => m.MaterialId, Model.selectList)
</div>

然后在您的整体形式中,您可以调用:

@Html.EditorFor(m => m.materialSelect)

这将自动枚举您的集合并为集合中的每个项目呈现编辑器模板。

于 2013-04-16T12:09:39.437 回答
5

假设计数从 0 开始,并且您的操作发布方法接收到 ViewModel 类型的参数,您可以尝试为每个下拉列表绑定 MaterialId:

foreach (var item in Model.materialSelect)
{
    count++;
    <div class="editor-label">
       Name for de dropdown
    </div>
    <div class="editor-field">
        @Html.DropDownList("materialSelect[" + count + "].MaterialId ", item.selectList)
        @Html.ValidationMessageFor(model => model.gradationId)
    </div>       
}
于 2013-04-16T10:37:44.090 回答