我想为多个条件(文档http://tabulator.info/docs/4.5/filter#search-data)过滤我的制表器表格,并为此创建以下功能:
function concepts() {
table.setFilter("type", "like", "keyword1");
table.setFilter("type", "like", "keyword2");
table.setFilter("type", "like", "keyword3");
}
当我运行该函数时,制表符仅显示与过滤器table.setFilter("type", "like", "keyword3");
的最后一行匹配的行,而忽略其他关键字的搜索。有没有办法让制表符显示包含keyword1
,keyword2
或keyword3
的行?
答案 0 :(得分:4)
实际上只考虑了setFilter的最后一次调用,这就是为什么不考虑firsts关键字的原因。
如果您确定数据将与三个关键字之一匹配,则可以使用Array In。
table.setFilter("type", "in", ["keyword1", "keyword2", "keyword3"]);
在您的示例中,看起来您想使用“喜欢”类型。在这种情况下,您应该在对象数组中定义3个过滤器,如下所示。
table.setFilter([
{"field": "type", "type": "like", "value": "keyword1"},
{"field": "type", "type": "like", "value": "keyword2"},
{"field": "type", "type": "like", "value": "keyword3"},
]);
这两个解决方案均来自您链接的文档:
http://tabulator.info/docs/4.5/filter(在数组中和应用多个过滤器部分)