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本身中设置Text和Value的字段.这就是为什么它对.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)
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)
试试这个,只是一个例子:
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)
| 归档时间: |
|
| 查看次数: |
210778 次 |
| 最近记录: |