在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中显示select列表中的数据.净的核心

(我不太熟悉ASP中的标签助手语法。. NET Core,但我会给它一个机会,如果我错了,请纠正我)

  • asp-for=""属性不需要@前缀,因为它不是Razor代码,属性值已经由ASP处理。. NET的解析器——只有当你使用与HTML有歧义的c#语法(例如双引号)时才需要它。
  • asp-controllerasp-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>