Filtering column's collection

Filtering column's collection

本文关键字:collection column Filtering      更新时间:2023-09-26

在我的Webix数据表中,一列从DataColletion中获取数据。问题在于列的过滤:似乎它处理原始数据(包含ID),而忽略了数据集合的值。如何更改此行为并根据集合的值筛选数据表?

数据:

var mycollection = new webix.DataCollection({  
  data:[{
    id: '12',
    value: 'CollItem 1'
  }]
});
var mydata = [{
  id: 1, 
  name: 'Item 1', 
  troublesomeColumn: '12' // id of the CollItem 1
}];
配置:

columns:[{
  id: 'troublesomeColumn',
  collection: mycollection,
  header:{
    content:"textFilter"
  }
}],
data:mydata

代码片段。

过滤器对数据集起作用,而不是对链接集合中的模板或值起作用。因此,你需要创建一个自定义的过滤规则,如在Webix文档中描述的,即定义所需的模式在过滤器的compare属性:

  {
    content:"textFilter",
    compare:function(value, filter, obj){
      var colValue = mycollection.getItem(value).value;
      toFilter = colValue.toString().toLowerCase();                            
      filter = filter.toString().toLowerCase();
      return toFilter.indexOf(filter) !== -1;
    }
  }

更新片段