Kendo 数据源筛选器未按预期工作

Kendo Datasource filter not working as expected

我正在使用 Kendo MVC 网格来显示数据。我必须根据用户点击的 url 过滤数据。下面是 Kendo 网格

的代码

查看

@(Html.Kendo().Grid<WebApplication2.ApplicationViewModel>()
        .Name("grid")
        .Columns(columns =>
        {
            columns.Bound(c => c.ApplicationStatus).Width(150);
            columns.Bound(c => c.StartDate).Width(150).Filterable(ftb => ftb.Cell(cell => cell.Operator("equals")));
            columns.Bound(c => c.EndDate).Width(150).Filterable(ftb => ftb.Cell(cell => cell.Operator("equals"))).Groupable(false);                        
        })
               .HtmlAttributes(new { style = "height: 500px;width:100%" })
                .Groupable()
       .Scrollable()
       .Filterable(ftb => ftb.Mode(Kendo.Mvc.UI.GridFilterMode.Row)) // Filter Code
       .Sortable()
       .Pageable(pageable => pageable
       .Refresh(true)
       .PageSizes(true))
       .DataSource(dataSource => dataSource
       .Ajax()
       .ServerOperation(true)
       .Read(read => read.Action("FetchData", "Home"))
                       .Filter(f => f.Add(p => p.ApplicationStatus).IsEqualTo(ViewBag.ApplicationStatus))
                       .Filter(f => f.Add(p => p.StartDate).IsGreaterThanOrEqualTo(Convert.ToDateTime(ViewBag.FromDate)))
                       .Filter(f => f.Add(p => p.StartDate).IsLessThanOrEqualTo(Convert.ToDateTime(ViewBag.ToDate)))
       .PageSize(KendoGridConstants.KendoGridDefaultPageSize)
       )
    )

控制器代码:

public ActionResult ApplicationGrid(string ApplicationStatus, string fromDate, string toDate)
        {            
            ViewBag.ApplicationStatus = ApplicationStatus == null ? "All" : ApplicationStatus;
            ViewBag.FromDate = fromDate == null ? DateTime.Now.ToShortDateString() : Convert.ToDateTime(fromDate).ToShortDateString();
            ViewBag.ToDate = toDate == null ? DateTime.Now.ToShortDateString() : Convert.ToDateTime(toDate).ToShortDateString();
            return View();
        }

        public ActionResult FetchData([DataSourceRequest]DataSourceRequest request)
        {
           var applicationList = Dbcontext.ApplicationStatus;
            return Json(applicationList.ToDataSourceResult(request), JsonRequestBehavior.AllowGet);
        }

如果我在 StartDate 上只保留一个过滤器,它工作正常,但如果我保留两个过滤器,它会显示一些不相关的数据。 我需要过滤日期范围。任何其他选择也可以。

我知道这真的很老了,但我遇到了同样的问题,找不到文档,结果一如既往地出现在 Stack Overflow 上。所以我正在贡献我的解决方案。

需要向 DataSource 上的 Filter 语句添加额外的和/或运算符:

.Read(read => read.Action("FetchData", "Home"))
  .Filter(f => f.Add(p => p.StartDate).IsGreaterThanOrEqualTo(Convert.ToDateTime(ViewBag.FromDate)))
       .And().IsLessThanOrEqualTo(Convert.ToDateTime(ViewBag.ToDate)))