如何使用Razor中的编辑器模板创建单选按钮组

时间:2012-06-12 19:00:35

标签: asp.net asp.net-mvc asp.net-mvc-3 razor mvc-editor-templates

我有以下型号

 public class FilterSetting
{
    public FilterType Type { get; set; }
    public ShowOption Option { get; set; }
    public bool IsMultiple { get; set; }
    public List<int> SelectedValues { get; set; }
    public List<SelectListItem> Values { get; set; }
    public int RowCount { get; set; }
}
public enum ShowOption
{
    Common,
    Also,
    All
}

我想为ShowOption枚举创建一个单选按钮组,但我想使用编辑器模板显示该组,因为我有另一个模型创建一个FilterSetting列表,它将显示大约7个FilterSettings,每个都必须具有ShowOption属性的一组3个单选按钮。

问题是当剃刀从编辑器模板渲染单选按钮时,它为每个单选按钮使用相同的名称(name =“filter.Option”),我不知道如何设置值。

这是我的编辑模板

@model Models.FilterSetting


@Html.RadioButtonFor(f => f.Option, "Common", new { id = ""+ Model.Type })
@Html.Label(""+Model.Type, "Show only common assets")
<br />
@Html.RadioButtonFor(f => f.Option, "Also", new { id = "" + Model.Type })
@Html.Label(""+Model.Type, "Also show assets matching the values selected below")
<br />
@Html.RadioButtonFor(f => f.Option, "All", new { id = "" + Model.Type })
@Html.Label(""+Model.Type, "Show all assets")
<br />


@if (Model.IsMultiple)
{
    @Html.ListBoxFor(f => f.SelectedValues, Model.Values)
}
else
{ 
    @Html.DropDownListFor(f => f.SelectedValues, Model.Values, new { size = "4" })
}

我尝试在htmlAttributes对象上传递名称,但它不起作用。

修改 显然问题是我打电话给编辑的方式。 我以这种方式称呼它

@foreach (var filter in Model.FilterSettings)
{
      ....
      @Html.EditorFor(f => filter)
}

当我这样称呼它时

@Html.EditorFor(f => f.filterSettings)

单选按钮正常工作。当我为每个人做的时候会发生什么?

感谢您的帮助!

2 个答案:

答案 0 :(得分:1)

当您为集合调用Editor/EditorFor时,Razor会跟踪生成的名称和ID,因此您将获得为ex生成的名称。 Addresses[0].Line1Addresses[1].Line1 ...

但是当你自己迭代这个集合并为每个模型剃刀调用编辑器时,不要保留名称和id的轨迹(它应该怎么样?那不会更复杂吗?)并且它被认为是一个新的控件将在页面中呈现。

答案 1 :(得分:0)

通常我使用@ Html.HiddenFor(x =&gt; x.id)和@ Html.HiddenFor(x =&gt; x.name),试试这个