24

这是我的代码。如果您想遍历所有行,它可以工作。现在,QA 告诉我我必须让它支持过滤器。因此,当用户使用过滤器时,只有一部分行会显示在网格上。我只需要遍历那些行。

    var entityGrid = $("#EntitesGrid").data("kendoGrid");       
    var data = entityGrid.dataSource.data();
    var totalNumber = data.length;

    for(var i = 0; i<totalNumber; i++) {
        var currentDataItem = data[i];
        VersionIdArray[i] = currentDataItem.VersionId;
    }

我试过。

    var data = entityGrid.dataSource.data().fetch();

    var data = entityGrid.dataSource.data().filter();

无法让它工作。

4

2 回答 2

26

为了将来参考和感兴趣的人,我在以下位置找到了解决方案:

http://colinmackay.scot/2012/07/23/kendo-ui-paging-and-accessing-the-filtered-results-in-javascript/

它的工作原理是首先获取网格的数据源,获取过滤器和数据,使用数据创建新查询并将过滤器应用于它。虽然这确实会导致获得过滤器的结果,但它确实具有处理两次过滤器操作的明显缺点。

function displayFilterResults() {
    // Gets the data source from the grid.
    var dataSource = $("#MyGrid").data("kendoGrid").dataSource;

    // Gets the filter from the dataSource
    var filters = dataSource.filter();

    // Gets the full set of data from the data source
    var allData = dataSource.data();

    // Applies the filter to the data
    var query = new kendo.data.Query(allData);
    var filteredData = query.filter(filters).data;

    // Output the results
    $('#FilterCount').html(filteredData.length);
    $('#TotalCount').html(allData.length);
    $('#FilterResults').html('');
    $.each(filteredData, function(index, item){
        $('#FilterResults').append('<li>'+item.Site+' : '+item.Visitors+'</li>')
    });
}
于 2012-10-22T18:55:15.267 回答
6

非常感谢!!!现在有了这个帮助,我做到了......

kendo.data.DataSource.prototype.dataFiltered = function () {
    // Gets the filter from the dataSource
    var filters = this.filter();

    // Gets the full set of data from the data source
    var allData = this.data();

    // Applies the filter to the data
    var query = new kendo.data.Query(allData);

    // Returns the filtered data
    return query.filter(filters).data;
}

所以现在我可以很容易地得到我的过滤数据!!!惊人的!!!

例子:

var dataFiltered = $("#MyGrid").data("kendoGrid").dataSource.dataFiltered();
于 2014-11-19T19:41:15.770 回答