1

今回はAPIからデータを取得していますが、フィルタリングしたいと思います。ログインはこちら。ユーザー -> ステータスによるフィルター (有効または無効)

次のファイルがあります

  • people.component.ts
  • people.component.html
  • people.pipe.ts

JSON ファイル

  • {"名前": "アナ","ステータス": "有効"},
  • {"名前": "マルセロ","ステータス": "有効"},
  • {"名前": "ロッド","ステータス": "無効"}

people.component.ts

export class peopleComponent implements OnInit {

    /* General Variables */
    titlePage: string = "People";
    errorMessage: string;
    filterPeople: string  = "Enable";

    people: iPeople[]; // Call the service, this is fine 

    constructor(private _peopleService: peopleListService){

    }
    ngOnInit(): void {
    this._peopleService.getInfo()
        .subscribe(
            people => this.people = people,
            error => this.errorMessage = <any>error);
    }
}

people.pipe.ts

@Pipe({
    name: 'peopleTab'
})
export class peopleTabsPipe implements PipeTransform {
    transform(value: iPeopleList[], args: string[]): iPeopleList[] {
        let filter: string = args[0] ? args[0].toLocaleLowerCase() : null;
        return filter ? value.filter((people: iPeopleList) => people.Status.toLocaleLowerCase().indexOf(filter) != -1) : value;
    }
}

people.component.html

<template ngFor #person [ngForOf]="people | peopleTab:filterPeople">
      <div class="Tabs">
            <ul>
               <li class="active" data-tab="1"><a href="javascript:void(0);">Active</a></li>
               <li data-tab="2"><a href="javascript:void(0);">Past</a></li>
            </ul>
         </div>
      <div class="information">{{person.Name}} {{person.Status}}</div>
</template>

デフォルトでは「有効」でフィルタリングされていますが、変数を過去のタブに転送してフィルターの値を変更することはできません

4

1 に答える 1