尝试使用两个下拉列表进行筛选

本文关键字:下拉列表 两个 筛选 | 更新日期: 2023-09-27 18:37:25

我正在使用MVC,我正在尝试通过两个下拉列表过滤数据。

我有一个工作,只是不知道让第二个工作的逻辑

这是我的代码:

控制器:

    public ActionResult Index(int? DepartmentID, int? JobTitleID)
    {
        DepartmentDropDownList();
        JobDropDownList();
        var employees = db.Employees.Include(e => e.Department).Include(e => e.JobTitle);
        if (DepartmentID.HasValue || JobTitleID.HasValue)
        {
            employees = employees.Where(j => j.JobTitleID == JobTitleID);
            //somehow filter departments here
        }
        return View(employees.ToList());
    }

视图:

@model IEnumerable<josh_MVC_Company.Models.Employee>
@{
    ViewBag.Title = "Index";
}
<h2>Index</h2>
@using (Html.BeginForm())
{
    <p> Select by Department: @Html.DropDownList("DepartmentID", "Departments")  </p>
    <p> Select by Job Title: @Html.DropDownList("JobTitleID","Job Titles")  </p>
        <input type="submit" value="Filter" />
}

尝试使用两个下拉列表进行筛选

在具体化 LINQ 查询之前,必须按这两个字段进行筛选 ( ToList() )。

if (JobTitleID.HasValue)
    {
        employees = employees.Where(j => j.JobTitleID == JobTitleID.Value);
    }
if (DepartmentID.HasValue)
    {
        employees = employees.Where(j => j.DepartmentID == DepartmentID.Value);
    }
return View(employees.ToList());

这样,如果没有任何值存在,则根本不会对其进行筛选。

(如您所见,您可以根据需要链接任意数量的Where(Expression<Func<T,bool>>)