我需要编写一个自定义过滤器功能。我有一个多列的剑道网格,即姓名、年龄、城市。名称列应该是多选的。现在,在过滤时,整个网格上的逻辑应该是“和”,但特定列(名称)应该有一个“或”逻辑。
我看过这篇文章和其他几个类似的帖子。在此示例中,telerik 建议删除 data-bind 属性
element.removeAttr("data-bind");
这非常有效,直到我想清除多选字段中的所有标签。仅供参考,网格配置为 filterMode: "row"。在这种情况下,标签根本不会清除。
所以现在,我在这里尝试编写一个自定义过滤器函数。这是我到目前为止所拥有的:
filterable: {
multi: true,
cell: {
template: function getteamplate(args) {
args.element.kendoMultiSelect({
dataSource: args.dataSource,
dataTextField: "name",
dataValueField: "name",
change: function change(e) {
var dataSource = $scope.grid.dataSource;
// if filters are not yet set, do so now
if (!dataSource.filter()) {
$scope.grid.dataSource.filter({
logic: "and",
filters: []
});
}
var dataFilters = dataSource.filter().filters;
var values = this.value();
if (values.length > 0) {
$log.log("filtering");
var newFilter = {
field: "name",
operator: function operator(item, value) {
$log.log("Item: " + item);
$log.log(value());
var found = false;
value().forEach(function forEach(element) {
$log.log("Value: " + element);
if (item.indexOf(element) !== -1) {
found = true;
}
});
return found;
},
value: values,
fieldName: "dataSource"
};
dataFilters.push(newFilter);
$log.log(dataFilters);
}
dataSource.filter({
logic: "and",
filters: dataFilters
});
}
});
//args.element.removeAttr("data-bind");
},
showOperators: false
}
}
有几点值得注意
- 我的自定义过滤器功能似乎永远不会执行,因为我在控制台中看不到任何东西。
在此论坛帖子之后,此代码似乎非常简单:
operator: function(item, value){ //实现你的逻辑 }
除非它没有很好地记录,而且我不确定参数“item”和“value”是什么或它们来自哪里。