1. ホーム
  2. angular

[解決済み] ngForにフィルターをかけるには?

2022-02-03 09:22:18

質問

どうやらAngular2では、ng-forと連携して結果をフィルタリングするために、Angular1のようにフィルタではなくパイプを使うようです。しかし、まだ実装が曖昧で、明確なドキュメントがないようです。

つまり、私が実現しようとしていることは、次のような観点で見ることができます。

<div *ng-for="#item of itemsList" *ng-if="conditon(item)"></div>

パイプを使ってどのように実装するか?

どのように解決するのですか?

基本的には、パイプを書き、それを *ngFor ディレクティブを使用します。

コンポーネントで

filterargs = {title: 'hello'};
items = [{title: 'hello world'}, {title: 'hello kitty'}, {title: 'foo bar'}];

テンプレートでは、文字列、数値、またはオブジェクトをパイプに渡して、フィルタリングに使用することができます。

<li *ngFor="let item of items | myfilter:filterargs">

あなたのパイプの中に

import { Pipe, PipeTransform } from '@angular/core';

@Pipe({
    name: 'myfilter',
    pure: false
})
export class MyFilterPipe implements PipeTransform {
    transform(items: any[], filter: Object): any {
        if (!items || !filter) {
            return items;
        }
        // filter items array, items which match and return true will be
        // kept, false will be filtered out
        return items.filter(item => item.title.indexOf(filter.title) !== -1);
    }
}

でパイプを登録することを忘れないでください。 app.module.ts にパイプを登録する必要はありません。 @Component

import { MyFilterPipe } from './shared/pipes/my-filter.pipe';

@NgModule({
    imports: [
        ..
    ],
    declarations: [
        MyFilterPipe,
    ],
    providers: [
        ..
    ],
    bootstrap: [AppComponent]
})
export class AppModule { }

プランカーはこちら カスタムフィルタパイプと組み込みのスライスパイプを使って結果を制限するデモを行います。

なお、(何人かのコメンテーターが指摘しているように)、このような 訳あり Angularに組み込みのフィルターパイプがない理由。