ag-grid:为网格预先设置(默认)过滤器

时间:2017-07-05 02:29:38

标签: javascript reactjs ag-grid ag-grid-react

我有一个反应应用程序,一切似乎工作正常。 我希望通过过滤添加额外的功能,尽管我目前卡住了。

任何人都可以就如何预设过滤器提供一些建议

使用我见过的示例过滤方法in this article我试图实现一个基本的例子,虽然它不起作用

this.state = {
   gridOptions: {
  .
  .
  .
      onGridReady: this.initialFilter
}, 

initialFilter(){
    tmp = {Currency: {type: 'contains', filter: 'usd'}};
    this.state.gridOptions.api.setFilterModel(tmp);
    this.state.gridOptions.api.onFilterChanged();

} 

我对此运行的期望是“货币”列将针对包含过滤器文本usd的条件进行过滤

=============================================== == 编辑: 在尝试之后

initialFilter(){
    let hi=this.state.gridOptions.api.getFilterInstance('Currency');
    hi.setType('contains');
    hi.setFilter('usd');
    hi.onFilterChanged();
} 

什么都没发生+没有错误

但是当我在现有方法中添加代码以更改过滤器时(当我手动添加过滤器时):

onAfterFilterChanged() {
    let hi=this.state.gridOptions.api.getFilterInstance('Currency');
    hi.setType('contains');
    hi.setFilter('usd');
    hi.onFilterChanged();

    this.setState({
        rowsToDisplay: this.state.gridOptions.api.filterManager.rowModel.rowsToDisplay.length,
        filtering: this.props.report.views.filters
    });
    this.props.filterme(this.state.filtering);      
}

然后我得到以下错误

Full error: Uncaught RangeError: Maximum call stack size exceeded
at RowRenderer.workOutFirstAndLastRowsToRender (dme-ui-buidle.js:13181)
at RowRenderer.drawVirtualRows (dme-ui-buidle.js:13178)
at RowRenderer.refreshAllVirtualRows (dme-ui-buidle.js:13138)
at RowRenderer.refreshView (dme-ui-buidle.js:13034)
at RowRenderer.onModelUpdated (dme-ui-buidle.js:12979)
at RowRenderer.onPageLoaded (dme-ui-buidle.js:12931)
at dme-ui-buidle.js:2684
at Array.forEach (<anonymous>)
at EventService.dispatchEvent (dme-ui-buidle.js:2683)
at PaginationProxy.onModelUpdated (dme-ui-buidle.js:27264)

1 个答案:

答案 0 :(得分:0)

根据此处的文件:

https://www.ag-grid.com/javascript-grid-filtering/

和这个plunker:

https://plnkr.co/edit/0NoAA9cEZa1Zr9brMZ2I?p=info

这样的事情应该可以解决问题:

var yourFilterComponent = gridOptions.api.getFilterInstance('youfieldname');
yourFilterComponent.setType('contains');
yourFilterComponent.setFilter('usd');
yourFilterComponent.onFilterChanged();