gpt4 book ai didi

angular - 如何在 Angular Material 数据表中应用多个过滤器?

转载 作者:行者123 更新时间:2023-12-03 14:38:52 25 4
gpt4 key购买 nike

您好,有一个包含 4 个列的数据表 - 姓名、年龄、分数、学校。现在我想为每一列应用过滤器。过滤器单独工作正常。但我无法合并过滤器的结果 - 例如,我无法过滤掉分数 > 90 和来自“abc”学校的名称。

我尝试过这样的事情,但没有奏效。

applyFilter(filterValue: string) {
console.log("Filter is applied upon:",this.dataSource)
let initialDataSource = this.dataSource;
this.dataSource.filter = filterValue.trim().toLowerCase();
this.filteredDataSource = this.dataSource.filteredData
this.filterVal = this.dataSource.filter;
if(this.filterVal.length != 0){
this.dataSource = new MatTableDataSource(this.filteredDataSource);
this.dataSource.filter = filterValue.trim().toLowerCase();
}else{
this.dataSource = initialDataSource;
this.dataSource.filter = filterValue.trim().toLowerCase();
this.filteredDataSource = this.dataSource.filteredData
}
}

上面的函数做了过滤,但是当我清除过滤值时,表格数据没有改变。当我删除一个字符时它也不会改变。

最佳答案

为方便起见,声明 TableFilter 接口(interface):

interface ITableFilter {
column: string;
value: any;
}
应用过滤时,每行调用一次过滤谓词函数(!):如果谓词返回 true,则当前行将包含在过滤结果中。因此,如果其中一列不匹配,我们将遍历我们的过滤器数组并返回 false。
将您的 dataSource filterPredicate 替换为以下自定义项:
  setDataSource() {
this.dataSource = new MatTableDataSource(this.yourData);
this.dataSource.filterPredicate = this.customFilterPredicate;
}


customFilterPredicate(data: any, filters: ITableFilter[]): boolean {
for (let i = 0; i < filters.length; i++) {
const fitsThisFilter = data[filters[i].column].includes(filters[i].value);
if (!fitsThisFilter) {
return false;
}
}
return true;
}
之后,您可以像这样应用您的过滤器:
// implement some relevant logic to build the filters array
const filter: ITableFilter | any = [{column: 'name', value: 'foo'}, {column: 'description', value: 'bar'}];
// this is how you apply a filter
this.dataSource.filter = filter;
我们需要将过滤器设置为“任意”,这有点骇人听闻;但是过滤器函数需要一个字符串,我发现没有其他方法可以绕过它。

关于angular - 如何在 Angular Material 数据表中应用多个过滤器?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55757250/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com