Как изменить данные с помощью события изменения в Angular 8 - PullRequest
2 голосов
/ 21 июня 2020

Как изменить данные при использовании с событием (изменить). Я пытаюсь изменить элементы галереи, сопоставив значение, по умолчанию я хочу показать все элементы галереи

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 Ответ

2 голосов
/ 21 июня 2020

Демо это 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);       
  }
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...