与(更改)事件一起使用时如何更改数据。我正在尝试通过匹配值来更改图库项目,默认情况下,我想显示所有图库项目
public items = [{
value: 'All',
name: 'All Items'
},
{
value: 'Photos',
name: 'Photo Items'
},
{
value: 'Video',
name: 'Video Items'
},
];
<div *ngFor="let item of items" class="nav-li">
<ul>
<li class="value" [value]="item.value"><a href="">{{item.value}}</a></li>
</ul>
</div>
<div class="gallery">
<div *ngFor="let item of items" class="card">
<div class="data">{{item.name}}</div>
</div>
</div>
如果单击“照片”更改以显示照片数据,则显示所有项目。
答案 0 :(得分:2)
Demo这是带有管道的html
<div *ngFor="let item of items | customPipe : filter" class="card">
<div class="data">{{item.name}}</div>
</div>
在组件中创建过滤器值作为初始“全部”
filter='All'
列表中每个li的单击方法
<ul>
<li class="value"(click)="onChange(item.value)" [value]="item.value"><a href="">{{item.value}}</a></li>
</ul>
在组件中
onChange(value){
this.filter=value;
}
这是管道示例
import { Pipe, PipeTransform } from '@angular/core';
@Pipe({
name: 'customPipe'
})
export class CustomPipe implements PipeTransform {
transform(row: any[],filter:string): any {
return row.filter(x=>filter=='All' || x.value==filter);
}
}