在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) %>--%>