Kendo Datasource过滤器无法按预期工作

时间:2016-06-30 12:03:56

标签: asp.net-mvc kendo-grid kendo-asp.net-mvc

我使用Kendo MVC网格来显示数据。我必须根据用户点击的网址过滤数据。以下是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上只保留一个过滤器,它可以正常工作,但如果我同时保留两个过滤器,它会向我显示一些不相关的数据。 我需要按日期范围过滤。任何其他选择也没关系。

1 个答案:

答案 0 :(得分:1)

我知道这真的很老了,但我遇到了同样的问题,无法找到文档,并且一如既往地在Stack Overflow上结束了。所以我提供了解决方案。

需要在DataSource上的Filter语句中添加其他和/或运算符:

ventra