问题描述
|
我正在学习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.List1[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);
在您的代码“ 5”中是整数列表。不能将其强制转换为SelectListItem
。
边注:
code7ѭ变量未在您的代码中使用。
, 您需要将Int32
\的列表转换为SelectListItem
\的列表/ IEnumerable。您无法将其直接投射(这是您要执行的操作,并且是您的错误所代表的意思)。
您可以通过更改选择返回类型来调整LINQ查询以返回ѭ10。
var a = (from m in datacontext.services
select new SelectListItem{ Text = m.ServiceID.ToString(),Value = m.ServiceID.ToString() });
然后可以通过以下方式将其加载到a12ѭ中:
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>