gpt4 book ai didi

css - Angular:如何使用查询参数过滤数据表

转载 作者:搜寻专家 更新时间:2023-10-30 21:55:43 28 4
gpt4 key购买 nike

我想使用从另一个组件中的用户输入获得的查询参数来过滤我的表。

我能够获取用户通过输入发送的数据并将其打印到 console.log。但我不知道如何使用它来过滤表格。

我已经构建了一个过滤器,但由于某些原因我无法调用它。

这是我的过滤器:

import { Pipe, PipeTransform } from "@angular/core";
import { Container } from "./Entites/Container";

@Pipe({
name: 'textFilter'
})
export class textFilter implements PipeTransform {

transform(
containers : Container[],
storageSearch?: any,
clientSearch?: string,
): Container[] {

if (!containers) return [];
if (!storageSearch) return containers;
storageSearch = storageSearch.toLocaleLowerCase();
containers = [...containers.filter(user => user.TAOR_QTSR_EBRI.toLocaleLowerCase() === storageSearch)];

if (!clientSearch) return containers;
clientSearch = clientSearch.toLocaleLowerCase();
containers = [...containers.filter(user => user.LQOCH_SHM_LEOZI_QTSR.toLocaleLowerCase() === clientSearch)];

// if (!roleSearch) return users;
//roleSearch = roleSearch.toLocaleLowerCase();
//users = [...users.filter(user => user.role.toLocaleLowerCase() === roleSearch)];

return containers;
}
}

这是我的组件 ngOnInit 我还有一些其他过滤器,例如复选框过滤器:

  ngOnInit() {
this.marinService.getAllContainers().subscribe((result) => {
//Data
this.dataSource = new MatTableDataSource(result);
//Paginator
this.dataSource.paginator = this.paginator;
//AutoFilter Form 1st page
this.clientType = this.route.snapshot.queryParamMap.get('clientType');
this.storageType= this.route.snapshot.queryParamMap.get('storageTypes');
console.log('The Client name is : '+this.clientType+' '+'The storage Facility is : '+this.storageType);
//CheckBox Filter
this.dataSource.filterPredicate = (data: Container, filter: any) => {
return filter.split(',').every((item: any) => data.SOG_MCOLH.indexOf(item) !== -1);
};

this.filterCheckboxes.subscribe((newFilterValue: any[]) => {
this.dataSource.filter = newFilterValue.join(',');
});

});
}

我想要完成的是能够使用查询参数过滤表。

最佳答案

我们可以将您收到的数据作为输入(在父组件中)传递给子组件内的 Material 表过滤函数 applyFilter...

相关父TS:

import { Component } from '@angular/core';
@Component({
selector: 'app-root',
styles: [`.parent{background:lightgreen; padding:2%;}`],
template: `
Enter string for filtering: <input type='text' [(ngModel)]='inputStr' />
<!-- {{inputStr}} -->
<table-filtering-example [inputStr]='inputStr'>loading</table-filtering-example>
`,
})
export class AppComponent {
inputStr: string = '';
constructor() { }
}

相关子TS:

export class TableFilteringExample implements OnInit, OnChanges {
displayedColumns: string[] = ['position', 'name', 'weight', 'symbol'];
dataSource = new MatTableDataSource(ELEMENT_DATA);
@Input() inputStr:string;

constructor(){}

ngOnInit(){}

ngOnChanges(){
/* just call the applyFilter button with the data which is passed to your component from it's parent */console.log("(ngOnChanges)this.inputStr:", this.inputStr);
this.applyFilter(this.inputStr);
}

applyFilter(filterValue: string) {
this.dataSource.filter = filterValue.trim().toLowerCase();
}
}

完成working stackblitz here

关于css - Angular:如何使用查询参数过滤数据表,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56848421/

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