如果你打电话
grid.dataSource.filter({})
有可能您会删除整个 dataSource 过滤器,而不仅仅是网格中的字段。我的意思是 dataSource 可以出于某种原因进行预过滤。
我开发了一种方法,它只删除网格的过滤器。
kendo.ui.Grid.prototype.clearFilters = function(args){
var ignore = [];
// test arguments
if(typeof args === 'object'){
if(args.hasOwnProperty('ignore')){
if(args.ignore.length > 0){
ignore = args.ignore;
}
}
}
// get dataSource of grid and columns of grid
var fields = [], filter = this.dataSource.filter(), col = this.columns;
if( $.isEmptyObject(filter) || $.isEmptyObject(filter)) return;
// Create array of Fields to remove from filter and apply ignore fields if exist
for(var i = 0, l = col.length; i < l; i++){
if(col[i].hasOwnProperty('field')){
if(ignore.indexOf(col[i].field) === -1){
fields.push(col[i].field)
}
}
}
if($.isEmptyObject(fields)) return;
// call "private" method
var newFilter = this._eraseFiltersField(fields, filter)
// set new filter
this.dataSource.filter(newFilter);
}
这是第二种方法。它是分开的,因为它可以递归调用:
kendo.ui.Grid.prototype._eraseFiltersField = function(fields, filter){
for (var i = 0; i < filter.filters.length; i++) {
// For combination 'and' and 'or', kendo use nested filters so here is recursion
if(filter.filters[i].hasOwnProperty('filters')){
filter.filters[i] = this._eraseFiltersField(fields, filter.filters[i]);
if($.isEmptyObject(filter.filters[i])){
filter.filters.splice(i, 1);
i--;
continue;
}
}
// Remove filters
if(filter.filters[i].hasOwnProperty('field')){
if( fields.indexOf(filter.filters[i].field) > -1){
filter.filters.splice(i, 1);
i--;
continue;
}
}
}
if(filter.filters.length === 0){
filter = {};
}
return filter;
}
方法可以这样调用:
$('#my-grid').data('kendoGrid').clearFilters({
ignore: ['Field1', 'Field2']
})
存在递归是因为 dataSource 过滤器看起来像:
{
logic: "and"
filters: [
{
logic: "or"
filters:[
{
field: "Field1"
operator: "contains"
value: "val1"
},
{
field: "Field1"
operator: "contains"
value: "val2"
}
],
},
{
field: "Field3"
operator: "contains"
value: "val3"
}
],
}
和方法在所有嵌套的“过滤器”数组上递归调用。上面的过滤器是这样的:
("Field3" === "val3" && ("Field1" === "val1" || "Field1" === "val2" ) )
该方法并不完美,并且经过了一些测试。我希望这可以帮助别人。