手动将SelectListItem添加到SelectList以在DropDownListFor中使用

时间:2015-04-25 19:08:35

标签: c# asp.net asp.net-mvc-4 html.dropdownlistfor selectlist

当我创建SelecList时,我希望能够手动添加SelecListItem并执行此操作,我使用此代码:

List<SelectListItem> Provinces = new List<SelectListItem>();
Provinces.Add(new SelectListItem() { Text = "Northern Cape", Value = "NC" });
Provinces.Add(new SelectListItem() { Text = "Free State", Value = "FS" });
Provinces.Add(new SelectListItem() { Text = "Western Cape", Value = "WC" });

SelectList lstProvinces = new SelectList(Provinces);

而不是:

var lstProvinces = new SelectList(new[] { "Northern Cape", "Free State", "Western Cape" });

创建SelectList后,我通过ViewBag将它传递给DropDownListFor:

Html.DropDownListFor(m => m.StartPointProvince, (SelectList)ViewBag.Provinces)

然而,当我使用第一种方法创建SelectList时,它不起作用 - 它将3个值添加到下拉列表中,但所有值显示为: Code *输出截图

然而,当我使用第二种方法时,它工作正常。 我希望使用第一种方法,因为我希望能够指定每个项目的文本AND值。

4 个答案:

答案 0 :(得分:16)

问题在于SelectList(IEnumerable) constructor doesn't accept SelectListItem's(至少不会SelectListItem添加到其Items集合中。它只接受一些任意对象的集合,这些对象将用于生成完全不相关的内部SelectListItem集合。

如果需要,可以这样使用SelectList(IEnumerable, string, string)构造函数:

List<SelectListItem> Provinces = new List<SelectListItem>();
Provinces.Add(new SelectListItem() { Text = "Northern Cape", Value = "NC" });
Provinces.Add(new SelectListItem() { Text = "Free State", Value = "FS" });
Provinces.Add(new SelectListItem() { Text = "Western Cape", Value = "WC" });

this.ViewBag.Provinces = new SelectList(Provinces, "Value", "Text");

它会起作用。但它是不必要的,因为您创建了SelectListItem不会使用的复杂SelectList项 - 它只会将它们视为任何其他数据对象。

以同样的方式,您可以使用其他更简单的类来代替SelectListItem

public class SelectListModel
{
    public String Text { get; set; }
    public String Value { get; set; }
}

...
Provinces.Add(new SelectListModel() { Text = "Northern Cape", Value = "NC" });

答案 1 :(得分:3)

使用DropDownList并将其命名为与模型的属性名称相同。我的是“ItemType”

     @Html.LabelFor(model => model.ItemType, new { @class = "control-label" })
     @Html.DropDownList("ItemType", (IEnumerable<SelectListItem>)ViewBag.ItemTypes, new { @class = "form-control" })
     @Html.ValidationMessageFor(model => model.ItemType, null, new { @class = "text-danger" })

        var types = new List<SelectListItem>();
        types.Add(new SelectListItem() { Text = "Select...", Value = string.Empty });
        types.Add(new SelectListItem() { Text = "OTC", Value = "0" });
        types.Add(new SelectListItem() { Text = "Generic", Value = "1" });
        types.Add(new SelectListItem() { Text = "Brand", Value = "2" });
        types.Add(new SelectListItem() { Text = "Non-Merchandise", Value = "9" });

        ViewBag.ItemTypes = types;
    [Required(ErrorMessage = "Item Type is required")]
    public Int32 ItemType { get; set; }

答案 2 :(得分:3)

您可以从

更改代码
SelectList lstProvinces = new SelectList(Provinces);

SelectList lstProvinces = new SelectList(Provinces, "Value", "Text");

它会正确显示省份。

答案 3 :(得分:0)

您不需要使用 SelectList
相反,将 List<SelectListItem> 个省放入 ViewBag 并返回 ViewBag。 然后在视图上放:

@Html.DropDownList("Dropwonlist", (IEnumerable<SelectListItem>)ViewBag.YourData)