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) 这是错误
这是我的控制器 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的构造函数中使用这种代码.其他人应该将其分配给模型. 然后,您应该可以在视图中删除您的演员表. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |