在ASP.NET MVC中填充DropDownlist
本文关键字:填充 DropDownlist MVC ASP NET | 更新日期: 2023-09-27 17:58:53
我正在学习ASP.NET MVC。我在处理下线时遇到了一个小问题。
这就是我在控制器中所做的
List<Int32> myList = new List<Int32>();
var a = (from m in datacontext.services
select m.ServiceID);
myList = a.ToList();
ViewData["ServiceID"] = new SelectList((IEnumerable<SelectListItem>)
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.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
的列表中。
旁注:myList
变量未在代码中使用。
您需要将Int32
的列表转换为SelectListItem
的list/IEnumberable。您不能作为直接转换来执行此操作(这是您尝试执行的操作,也是您错误表示的操作)。
您可以通过更改选择返回类型来调整LINQ查询以返回IEnumerable<SelectListItem>
。
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);
}
视图:
<div class="class">
<%: Html.DropDownList("StoreTypeID", (SelectList)ViewData["StoreTypes"]) %>
<%--<%: Html.DisplayTextFor(model => model.StoreTypeID) %>--%>
</div>