Asp.NetCore EntityFrameWorkCore 库模式使用Linq填充下拉菜单?
这里是我的代码:
型号:
public partial class Commodity
{
public Commodity()
{
}
public IEnumerable<SelectListItem> CommodityCodes { get; set; };
[Key]
public Guid Oid { get; set; } = Guid.NewGuid();
public string Code { get; set; }
public string Description { get; set; }
}
接口+库:
public interface ICommodityRepository
{
IEnumerable<Commodity> ListAll();
IEnumerable<string> GetCommodityDropDown();
IEnumerable<SelectListItem> GetSelectListItems(IEnumerable<string> elements);
}
Repository:
public IEnumerable<string> GetCommodityDropDown()
{
Commodity model = new Commodity();
var commodities = from c in model.Oid.ToString()
select c;
return new List<string>
{
commodities.ToString()
};
}
public IEnumerable<SelectListItem> GetSelectListItems(IEnumerable<string> elements)
{
var selectList = new List<SelectListItem>();
foreach (var element in elements)
{
selectList.Add(new SelectListItem
{
Value = element,
Text = element
});
}
return selectList;
}
控制器:
public IActionResult Index()
{
var codes = _commodityRepository.GetCommodityDropDown();
var model = new Commodity();
model.CommodityCodes = _commodityRepository.GetSelectListItems(codes);
return View(model);
}
最后我的看法:
<div class="form-group">
@Html.DropDownListFor(m => m.Code, Model.CommodityCodes,
"- Please select a Commodity -",new { @class = "form-control" })
</div>
如果你想IMPL然后使用SelectList构造函数。'new SelectList(context.Countries,“Oid”,“Code”)'https://msdn.microsoft.com/en-us/library/system.web.mvc .selectlist.selectlist(v = vs.118).aspx – JamieD77
或'IEnumerable Countries = context.Countries.Select(x => new SelectListItem {Value = x.Oid,Text = x.Code});' –
谢谢。你能告诉我哪个国家应该是什么样的财产? SelectListItem? Ienumerable ?? –