ASP.NET使用MVC将linq查询结果绑定到HTML.DropDownList()

时间:2013-10-02 15:34:19

标签: c# asp.net asp.net-mvc razor

我正在尝试使用单个数据库调用构建一个下拉列表。

我的表包含Id列和CompanyName列。我需要向用户显示CompanyName,当选择一个时,将页面的Id设置为Id。

我已经将一个简单的模型放在一起来存储信息:

using System;
using System.Collections.Generic;
using System.Data.Entity;
using System.Linq;
using System.Web;

namespace Portal.Models
{
    public class CompanyListId
    {
        public int Id { get; set; }
        public string CompanyName { get; set; }
    }

    public class CompanyListIdDBContext : DbContext
    {
        public DbSet<CompanyListId> Contacts { get; set; }
    }
}

但我在视图中遇到了控制器和剃须刀调用的问题。

我的控制器:

public void CompanyListIdSearch()
        {
            using (var dc = new CompanyListIdDBContext())
            {
                var content = from p in db.Companies
                                select new { p.CoId, p.CompanyName };
            }
        }

Razor在视图中调用:

<div id="partners" class="linen">

                        @{Html.DropDownList("CompanyListIdSearch", new SelectList(Model.CompanyName));}
                    </div>

抓取视图顶部的模型@model Portal.Models.CompanyListId

所以在高级别我想要做的是有一个用剃须刀标签调用控制器的视图,控制器用数据更新模型,然后在下拉列表中显示该数据。我是以错误的方式接近这个吗?

我收到此错误:

The model item passed into the dictionary is of type 'Portal.Models.DashboardContents', but this dictionary requires a model item of type 'Portal.Models.CompanyListId'. 

1 个答案:

答案 0 :(得分:3)

不完全。你无法像DropDownList那样调用方法。

首先,将这些项目集合放在ViewBag

using (var dc = new CompanyListIdDBContext())
{
    var content = from p in db.Companies
       select new { p.CoId, p.CompanyName };

    ViewBag.CompaniesList = content
        .Select(c => new SelectListItem
        {
            Text = c.CompanyName,
            Value = c.CoId.ToString()
        }).ToList();
}

确保在返回视图之前在操作结果中调用该函数。

最后,只需使用您的模型属性并切换到DropDownListFor

@Html.DropDownListFor(m => m.Id, ViewBag.CompaniesList);

更好的方法,是不使用ViewBag并使用视图模型。像这样:

public class CompanyViewModel
{
    public int Id { get; set; }
    public string CompanyName { get; set; }
    public List<SelectListItem> CompaniesList { get; set; }
}

然后你的行动方法就像:

public ActionResult YourAction()
{
    var model = new CompanyViewModel();

    using (var dc = new CompanyListIdDBContext())
    {
        var content = from p in db.Companies
            select new { p.CoId, p.CompanyName };

        model.CompaniesList = content
            .Select(c => new SelectListItem
            {
                Text = c.CompanyName,
                Value = c.CoId.ToString()
            }).ToList();
    }

    return View(model);
}

然后您的视图将使用新模型:

@model CompanyViewModel

然后你的下拉列表将是:

@Html.DropDownListFor(m => m.Id, Model.CompaniesList)