0

我正在使用 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" />
}
4

1 回答 1

1

You have to filter by both fields before materializing the LINQ query (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());

In this way, if none of the values is present, it won't be filtered at all.

(As you can see you can chain as many Where(Expression<Func<T,bool>>) as you want)

于 2013-10-29T15:10:34.217 回答