在asp.net中显示select列表中的数据.净的核心
本文关键字:数据 核心 列表 select asp net 显示 | 更新日期: 2023-09-27 18:11:23
我尝试了几种不同的方法。我不知道为什么,但我的SelectList/下拉列表是空的。没有显示任何数据。我不确定我哪里出错了。
我有ASP。. NET Core App. Entity Framework Core。Db。我正在使用存储库模式。
这是我的模型类
public partial class Commodity
{
public Guid Oid { get; set; }
public string Code { get; set; }
}
这是我的界面:
interface ICommodityRepository
{
IEnumerable<Commodity> GetAll();
}
我的库:
public class CommodityRepository : ICommodityRepository
{
private ltgwarehouseContext context;
public CommodityRepository()
{ }
public IEnumerable<Commodity> GetAll()
{
return context.Commodity.ToList();
}
}
我的控制器:
public class CommoditiesController : Controller
{
static readonly CommodityRepository commodities = new CommodityRepository();
public CommoditiesController(CommodityRepository commodities)
{ }
// GET: /<controller>/
public IEnumerable<Commodity> CommoditiesList()
{
return commodities.GetAll();
}
}
这是我的视图/HTML标记:
@model Lansing.BasisMap.Domain.Models.Commodity
<li><select asp-for="@Model.Code" asp-controller="Commodities" asp-action="CommoditiesList"></select> </li>
(我不太熟悉ASP中的标签助手语法。. NET Core,但我会给它一个机会,如果我错了,请纠正我)
-
asp-for=""
属性不需要@
前缀,因为它不是Razor代码,属性值已经由ASP处理。. NET的解析器——只有当你使用与HTML有歧义的c#语法(例如双引号)时才需要它。 -
asp-controller
和asp-action
属性不适用于<select>
- 您没有为您的
<select>
提供任何选项,使用asp-items
属性并提供IEnumerable<SelectListItem>
或SelectList
实例。这可以通过您的ViewModel
或(我的偏好)通过ViewData
(或ViewBag
)传递。
假设是ViewData
,那么:
public ActionResult YourControllerAction() {
// stuff
this.ViewData["items"] = commodities
.GetAll()
.Select( c => new SelectListItem() { Text = c.Code, Value = c.Oid.ToString() } )
.ToList();
// stuff
return this.View( viewModel );
}
并在视图中这样使用:
<select asp-for="Model.Code" asp-items="@ViewData["items"]" />
在这篇QA帖子中有更多的例子:. Core MVC
试试这个:
在视图:<select asp-for="Staff.CityID" asp-items="@Model.CityList"></select>
在控制器:public IActionResult Create()
{
StaffViewModel model = new StaffViewModel();
model.CityList = new List<SelectListItem>
{
new SelectListItem {Text = "İstanbul", Value = "1"},
new SelectListItem {Text = "Sivas", Value = "2"}
};
return View(model);
}
在模型:public class StaffViewModel
{
public Staff Staff { get; set; }
public List<SelectListItem> CityList { get; set; }
}
这可能是因为没有将数据库注入到CommodityRepository
中。为了使DI工作,您需要将参数添加到构造函数中。
public CommodityRepository(ltgwarehouseContext ltgwc)
{
context = ltgwc;
}
然后,如果你想让它自动填充并注入到你的控制器中,你需要使用services.Addxxx
方法之一在Startup.cs中注册它。我建议您阅读DI文档,因为它会比我更好地解释它。
你的最终控制器应该看起来像这样:
public class CommoditiesController : Controller
{
//Declare the local variable
ICommodityRepository _commodities;
//Load the repository via DI
public CommoditiesController(CommodityRepository commodities)
{
//Set the local variable to the injected one
_commodities = commodities;
}
// GET: /<controller>/
public IEnumerable<Commodity> CommoditiesList()
{
//Reference the local variable in your methods
return _commodities.GetAll();
}
}
在视图中还可以这样做:
@Html.DropDownListFor(model => model.ProvinceId, new SelectList(Model.provinces, "ID", "Description"), "Select Province"
, new {
@class = "form-select form-control",
id = "ProvinceDropDownList"})
然后ViewModel将是
public class Places
{
public string ProvinceId {get;set;}
public IEnumerable<tblprovinceDTO> provinces { get; set; }
}
控制器:
SelectList selectList=New SelectList(yourItems,"IdField","TitleField");
你可以发送这个变量与页面模型或视图数据
例如:
ViewData["SelectListData"]=selectList;
视图:
<select asp-items="ViewData["SelectListData"]" class="form-control"></select>