4

是否有任何实现的功能来有条件地隐藏行?

我像这样实例化它们:

let rows = [
    { name: "Adam", isVisible: true },
    { name: "Bert", isVisible: true },
    { name: "Carl", isVisible: false }
];

for(let row of rows)
  row["height"] = row.isVisible ? 25 : 0;

this.rowData = rows;

然后我提供这个函数来设置行高:

this.gridOptions.getRowHeight = (params) => {
    return params.data.height;
}

这不是一个完美的解决方案,特别是因为如果网格以高度为 0 的行结束,它无论如何都会显示该行(高度为 4px 左右)

4

2 回答 2

6

我认为最好的方法是根据isVisible对象的属性过滤数据。

一个实现可以是:

gridOptions.isExternalFilterPresent = () => {return true;}
gridOptions.doesExternalFilterPass = (node) => {
    return gridOptions.api.getValue("isVisible", node)
}

如果数据模型数据发生变化,那么您只需要调用gridOptions.api.onFilterChanged()

于 2017-08-24T14:10:57.253 回答
1

作为将行高设置为 0 时 4px 问题的解决方法,我建议您也使用

gridOptions.getRowStyle = function(params) {
            //some filter
            return { 'display': 'none' };
        }
于 2018-04-10T16:08:41.937 回答