我有一个下拉菜单,我想添加到MVC 5的_Layout.cshtml页面中。这是从数据库中的参考数据返回的-用于CarTypes。可以选择4种不同类型的汽车模型-轿车,4X4,Estate和Hatchback。

我创建了一个CarTypesViewModel,如下所示:

 public IEnumerable<SelectListItem> CarTypesList { get; set; }

 public string SelectedCarType { get; set; }


然后我有一个观点:

@using (Html.BeginForm("SomeAction", "SomeController", FormMethod.Get))
{
    //Just a html div here perhaps?
    @Html.DropDownListFor(model => model.SelectedCarType, Model.CarTypesList)
}


在布局中,我有以下内容:

<li id="selectedcar">@Html.Action("Index", "CarTypes")</li>


然后在我的CarTypes控制器中执行以下操作:

  var model = new CarTypesViewModel
        {
            CarTypesList= products.Select(p => new SelectListItem
            {
                Value = p.Id.ToString(CultureInfo.InvariantCulture),
                Text = p.Name
            })
        };

        return View(model);


这会将数据返回到下拉列表。但是,我真正想要的是值显示为“请选择您的汽车类型”作为列表中的第一项-实现此目标的最佳方法是什么,因为我不想将其存储为数据库中的值?

最佳答案

@Html.DropDownListFor(model => model.SelectedCarType,
    new SelectList(Model.CarTypesList, "Value", "Text"),
    "--- Please Select Your Car Type ---",
    new { @class = "form-control" }
)

10-06 14:36