*ngFor にフィルターを適用するにはどうすればいいですか? 質問する

*ngFor にフィルターを適用するにはどうすればいいですか? 質問する

どうやら、Angular 2 では、結果をフィルタリングするために、Angular1 のようにフィルターではなくパイプを ng-for と組み合わせて使用​​するようですが、実装はまだ曖昧で、明確なドキュメントはありません。

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

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

パイプを使用してこれを実装するにはどうすればよいでしょうか?

ベストアンサー1

基本的には、ディレクティブで使用できるパイプを記述します*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 に組み込みのフィルター パイプがない理由。

おすすめ記事