我有一个具有3个输入参数的组件
如何做到这一点,以便将name_filter
设置为过滤那组数据的管道?
@Input('json_columns') columns:[{}];
@Input('json_rows') rows:[{}];
//Pipe
@Input('name_filter') filter:string;
<tr *ngFor="let item of filas | filter: searchItem; let i=index" >
{{item.nombre}}
</tr>
答案 0 :(得分:1)
一种方法是创建一个函数“ getFilas()”并在该函数中实现过滤器
请参见以下示例:https://stackblitz.com/edit/angular-filter-data-in-component
这是模板
<div *ngFor="let item of getData(); let i=index">
{{i}} - {{item.name}} {{ item | json }}
</div>
这是组件中的相关代码
@Input() field: string;
@Input() value: string;
@Input() data: any[];
getData() {
return this.data.filter((item) => {
return item[this.field] == this.value;
})
}