SelectList的ASP.NET MVC下拉列表

Mat*_*ttW 43 c# asp.net-mvc drop-down-menu

我正在SelectList我的控制器中构建以下内容.

var u = new NewUser();

u.UserTypeOptions = new SelectList(new List<SelectListItem>
{
    new SelectListItem { Selected = true, Text = string.Empty, Value = "-1"},
    new SelectListItem { Selected = false, Text = "Homeowner", Value = ((int)UserType.Homeowner).ToString()},
    new SelectListItem { Selected = false, Text = "Contractor", Value = ((int)UserType.Contractor).ToString()},
});

return u;
Run Code Online (Sandbox Code Playgroud)

并在我的视图上显示如下:

@Html.DropDownListFor(m => m.UserType, Model.UserTypeOptions)
Run Code Online (Sandbox Code Playgroud)

看起来我在它SelectListItem应该是一个非常简单的下拉列表中给它一个有效的一组s,但是我没有获得<option>具有良好值和文本的有效列表,而是得到这个:

<select data-val="true" data-val-range="A user type must be selected." data-val-range-max="2" data-val-range-min="1" data-val-required="The UserType field is required." id="UserType" name="UserType" class="input-validation-error">
    <option>System.Web.Mvc.SelectListItem</option>
    <option>System.Web.Mvc.SelectListItem</option>
    <option>System.Web.Mvc.SelectListItem</option>
</select>
Run Code Online (Sandbox Code Playgroud)

是什么赋予了?据我所知,这应该有效.

Rom*_*ias 71

您缺少在SelectList本身中设置TextValue的字段.这就是为什么它对.ToString()列表中的每个对象执行操作的原因.你可以认为,鉴于它是一个列表,SelectListItem它应该足够智能来检测这个...但事实并非如此.

u.UserTypeOptions = new SelectList(
    new List<SelectListItem>
    {
        new SelectListItem { Selected = true, Text = string.Empty, Value = "-1"},
        new SelectListItem { Selected = false, Text = "Homeowner", Value = ((int)UserType.Homeowner).ToString()},
        new SelectListItem { Selected = false, Text = "Contractor", Value = ((int)UserType.Contractor).ToString()},
    }, "Value" , "Text", 1);
Run Code Online (Sandbox Code Playgroud)

顺便说一句,您可以使用任何类型的数组列表...然后只需设置将充当文本和值的属性的名称.

我认为最好这样做:

u.UserTypeOptions = new SelectList(
    new List<SelectListItem>
    {
        new SelectListItem { Text = "Homeowner", Value = ((int)UserType.Homeowner).ToString()},
        new SelectListItem { Text = "Contractor", Value = ((int)UserType.Contractor).ToString()},
    }, "Value" , "Text");
Run Code Online (Sandbox Code Playgroud)

我删除了-1项,并且每个项目的设置都选为true/false.

然后,在您的视图中:

@Html.DropDownListFor(m => m.UserType, Model.UserTypeOptions, "Select one")
Run Code Online (Sandbox Code Playgroud)

这样,如果设置"选择一个"项,并且未在SelectList中设置一个项目,UserType则将为空(UserType需要int?).

如果需要将其中一个SelectList项设置为选中,则可以使用:

u.UserTypeOptions = new SelectList(options, "Value" , "Text", userIdToBeSelected);
Run Code Online (Sandbox Code Playgroud)

  • 而您的最后一个片段完全是错误的。当使用`DropDownListFor()`绑定到属性时,将忽略SelectList构造函数的第4个选项-它的属性值决定了要选择的内容。 (2认同)

VnD*_*vil 15

只需用剃刀试试吧

@{
    var selectList = new SelectList(
        new List<SelectListItem>
        {
            new SelectListItem {Text = "Google", Value = "Google"},
            new SelectListItem {Text = "Other", Value = "Other"},
        }, "Value", "Text");
}
Run Code Online (Sandbox Code Playgroud)

然后

@Html.DropDownListFor(m => m.YourFieldName, selectList, "Default label", new { @class = "css-class" })
Run Code Online (Sandbox Code Playgroud)

要么

@Html.DropDownList("ddlDropDownList", selectList, "Default label", new { @class = "css-class" })
Run Code Online (Sandbox Code Playgroud)


Jai*_*min 6

试试这个,只是一个例子:

u.UserTypeOptions = new SelectList(new[]
    {
        new { ID="1", Name="name1" },
        new { ID="2", Name="name2" },
        new { ID="3", Name="name3" },
    }, "ID", "Name", 1);
Run Code Online (Sandbox Code Playgroud)

或者

u.UserTypeOptions = new SelectList(new List<SelectListItem>
    {
        new SelectListItem { Selected = true, Text = string.Empty, Value = "-1"},
        new SelectListItem { Selected = false, Text = "Homeowner", Value = "2"},
        new SelectListItem { Selected = false, Text = "Contractor", Value = "3"},
    },"Value","Text");
Run Code Online (Sandbox Code Playgroud)