如何在Angular 8中使用Change事件更改数据

时间:2020-06-21 09:00:17

标签: angular typescript

与(更改)事件一起使用时如何更改数据。我正在尝试通过匹配值来更改图库项目,默认情况下,我想显示所有图库项目

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>

如果单击“照片”更改以显示照片数据,则显示所有项目。

1 个答案:

答案 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);       
  }
}