加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

c# – 具有IEnumerable数据类型的下拉列表

发布时间:2020-12-16 00:17:04 所属栏目:百科 来源:网络整理
导读:我的模型看起来像这样 public IEnumerableSelectListItem ProductTypes { get; set; } public ProductContent() { productxEntities db = new productxEntities(); ProductTypes = db.ProductCodes.Select(c = new SelectListItem { Value = c.product_type.
我的模型看起来像这样

public IEnumerable<SelectListItem> ProductTypes { get; set; }

    public ProductContent()
    {
        productxEntities db = new productxEntities();

        ProductTypes = db.ProductCodes.Select(c => new SelectListItem
        {
            Value = c.product_type.ToString(),Text = c.code.ToString()
        });



    }

当我尝试将它用于DropDownList时,我得到一个错误,说明转换是错误的…在MVC3 Razor C#中使用DB的列表填充DDL的正确方法是什么,我对此模型类型有一个紧密耦合的视图.

@Html.DropDownList("ProductTypes",(IEnumerable<SelectListItem>) Model.ProductTypes)

这是错误

Unable to cast object of type ‘System.Data.Entity.Infrastructure.DbQuery1[System.Web.WebPages.Html.SelectListItem]' to type 'System.Collections.Generic.IEnumerable1[System.Web.Mvc.SelectListItem]’.

这是我的控制器

public ActionResult Create()
    {
        ProductContent productViewModel = new ProductContent();
        return PartialView("../PartialViews/NewProduct",productViewModel);
    }

解决方法

您应该在EF查询中的某处调用ToList.否则,您将直接向View返回Queryable.

可能是这样的:

public ProductContent()
{
    productxEntities db = new productxEntities();

    ProductTypes = db.ProductCodes.ToList().Select(c => new SelectListItem
    {
        Value = c.product_type.ToString(),Text = c.code.ToString()
    });
}

正如我在评论中提到的那样;我不鼓励在Model的构造函数中使用这种代码.其他人应该将其分配给模型.

然后,您应该可以在视图中删除您的演员表.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读