在ASP.NET MVC中填充DropDownlist

时间:2011-06-10 02:09:28

标签: c# .net asp.net asp.net-mvc asp.net-mvc-3

我正在学习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]'的对象。“

如何解决这个问题?

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

3 个答案:

答案 0 :(得分:4)

演员表中有错误。

要解决此问题,您可以这样做:

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变量。

答案 1 :(得分:0)

您需要将Int32的列表转换为SelectListItem的List / IEnumerable。你无法做到直接演员(这是你想要做的,以及你的错误代表什么)。

您可以通过更改选择返回类型来调整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);

答案 2 :(得分:0)

此外,如果您有一个下拉列表,您希望填充文本项,则可以执行以下操作:

控制器:

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>