在ASP.NET MVC中填充DropDownlist

我正在学习ASP.NET MVC。 处理dropdownlist时遇到了一个小问题。

这就是我在控制器中所做的

List myList = new List(); var a = (from m in datacontext.services select m.ServiceID); myList = a.ToList(); ViewData["ServiceID"] = new SelectList((IEnumerable) a.ToList(), "ServiceID", "ServiceID"); 

在视图中

  @Html.DropDownListFor(model => model.ServiceID, ViewData["ServiceID"] as SelectList) 

这会导致错误

无法将类型为’System.Collections.Generic.List 1[System.Int32]' to type 'System.Collections.Generic.IEnumerable对象1[System.Int32]' to type 'System.Collections.Generic.IEnumerable 1 [System.Web.Mvc.SelectListItem]’。“

怎么解决这个问题?

处理使用查询填充下拉列表的最佳方法是什么?

演员表中有错误。

要修复你可以这样做:

 var a = datacontext.services.Select(arg => new { ServiceID = arg.ServiceID }).ToList(); ViewData["ServiceID"] = new SelectList(a, "ServiceID", "ServiceID"); 

或这个:

 var a = datacontext.services.Select(arg => arg.ServiceID).ToList(); ViewData["ServiceID"] = new SelectList(a); 

在您的代码中, a是整数列表。 它不能被SelectListItem转换为SelectListItem列表。

附注: myList变量未在您的代码中使用。

您需要将Int32的列表转换为SelectListItem的List / IEnumerable。 您无法将此作为直接强制转换(这是您尝试执行的操作,以及您的错误代表的内容)。

您可以通过更改选择返回类型来调整LINQ查询以返回IEnumerable

 var a = (from m in datacontext.services select new SelectListItem{ Text = m.ServiceID.ToString(), Value = m.ServiceID.ToString() }); 

然后,您可以通过以下方式将其加载到SelectList

 ViewData["ServiceID"] = new SelectList(a); 

此外,如果您要在下拉列表中填充文本项,则可以执行以下操作:

控制器:

 public ActionResult Create() { var viewModel = new Store(); var storeTypes = new SelectList( ( from t in _db.StoreTypes select new SelectListItem { Text = t.StoreTypeName, Value = SqlFunctions.StringConvert((double)t.StoreTypeID) //convert int to string (yikes) } ) , "Value", "Text"); ViewData["StoreTypes"] = storeTypes; return View(viewModel); } 

视图:

 
<%: Html.DropDownList("StoreTypeID", (SelectList)ViewData["StoreTypes"]) %> <%--<%: Html.DisplayTextFor(model => model.StoreTypeID) %>--%>