Asp MVC下拉列表已选值未选中
本文关键字:MVC 下拉列表 Asp | 更新日期: 2023-09-27 18:01:31
我有以下下拉列表,但所选值似乎不起作用。默认为列表的第一项。
private List<string> GetTransmissions()
{
List<string> Transmission = new List<string>();
Transmission.Add("Automatic");
Transmission.Add("Manual");
return Transmission;
}
Car car = _repository.GetCarDetails(id);
ViewBag.Transmission = new SelectList(GetTransmissions(), car.Transmission);
在我看来,我有:
@Html.DropDownList("Transmission", (IEnumerable<SelectListItem>)ViewBag.Transmission, "Please Select", new { @class = "form-control" })
您需要区分保存列表的属性和保存选定值的属性。
我建议对视图使用如下的视图模型:
public class CarViewModel
{
public SelectList Transmissions
{
get
{
return new SelectList(new List<SelectListItem>{
new SelectListItem { Value = "Manual"},
new SelectListItem { Value = "Automatic"}
});
}
}
public string Transmission { get; set; }
}
并使用这个DropDownListFor版本
@Html.DropDownListFor(model => model.Transmission,
@Model.Transmissions, "Please Select", new { @class = "form-control" })
如果您仅限于使用ViewBag
而不是视图模型和@Html.DropDownList
Html Helper,那么我会做以下操作:
ViewBag.Transmissions = new SelectList(GetTransmissions()
.Select(t => new {value = t, text = t}),
"value", "text");
ViewBag.Transmission = car.Transmission;
上面创建了SelectList
,然后投影,使您的下拉菜单呈现文本和值。这保存在ViewBag.Transmissions
中,这是可用的选项。
然后用ViewBag.Transmission
设置你所选择的传输。
你的剃刀代码也需要更改为使用ViewBag.Transmissions
:
@Html.DropDownList("Transmission",
(IEnumerable<SelectListItem>)ViewBag.Transmissions,
"Please Select", new { @class = "form-control" })
工作小提琴修改
ViewBag.Transmission = new SelectList(GetTransmissions(), car.Transmission);
ViewBag.Transmissions = new SelectList(GetTransmissions(), car.Transmission);
Car模型已经包含了一个名为Transmission的属性,所以需要另一个ViewBag来保存这个属性。
在my razor代码中使用以下代码代替
@Html.DropDownList("Transmission", (IEnumerable<SelectListItem>)ViewBag.Transmissions, "Please Select", new { @class = "form-control" })