有了这样的表
1|2|3
4|1|1
1|1|1
现在我想按数字> = 3的列进行过滤,我会得到:
1|2|3
4|1|1
ClientFilter 库似乎仅适用于字符串(正则表达式实现)。有没有其他方法可以做到这一点?
有了这样的表
1|2|3
4|1|1
1|1|1
现在我想按数字> = 3的列进行过滤,我会得到:
1|2|3
4|1|1
ClientFilter 库似乎仅适用于字符串(正则表达式实现)。有没有其他方法可以做到这一点?
Backgrid 类很容易扩展,所以你需要做的就是创建你自己的过滤器类来覆盖 ClientSideFilter.makeMatcher
函数,如下所示:
var GreaterThanClientFilter = Backgrid.Extension.ClientSideFilter.extend({
makeMatcher: function(query){
var q = 1*query;
return function (model) {
if (isNaN(q)) return false;
var keys = this.fields || model.keys();
for (var i = 0, l = keys.length; i < l; i++) {
value = model.get(keys[i]);
if (!isNaN(value) && (1*value >= q))
return true;
}
return false;
};
}
});
var filter = new GreaterThanClientFilter({
collection: collection
});
运行示例:JSFiddle