どうやら、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 に組み込みのフィルター パイプがない理由。