私はObservable
とChangeDetectionStrategy
を使用して、他のコンポーネントに変更のお知らせを伝えようとしています。残念ながら、ObservableオブジェクトaddItemStream
は未定義です。ここで何が間違っていますか?角2.観測可能が定義されていません
import { Component, ChangeDetectionStrategy, ChangeDetectorRef, Input } from '@angular/core'
import { ROUTER_DIRECTIVES, Router } from '@angular/router';
import {Observable} from 'rxjs/Observable';
@Component({
selector: 'bp-header',
templateUrl: 'app/header.component.html',
directives: [ROUTER_DIRECTIVES],
changeDetection: ChangeDetectionStrategy.OnPush
})
export class HeaderComponent {
@Input() addItemStream: Observable<any>;
public isActive: number;
public language: string = "en";
constructor(private cd: ChangeDetectorRef) {}
ngOnInit() {
this.isActive = 1;
}
ngAfterViewInit() {
this.addItemStream.subscribe(() => {
this.setLanguage; // application state changed
this.cd.markForCheck();
})
}
public setLanguage = (language: string) => {
if (this.language === language) { return }
else { this.language = language };
}
public setActive(active: number) {
if (this.isActive === active) return;
this.isActive = active;
}
}
あなたはこの意味でください::ngAfterViewInit(){ this.addItemStream.subscribe(()=> { this.setLanguageをコンポーネントが最初に初期化するときしかし、流れはそうちょうどあなたのコンストラクタでそれを初期化定義されていません; this.cd.markForCheck(); } } –
上記のコードを更新しましたが、同じエラーがあります。 –
それは動作するはずですが、Observableをいつ、どこで作成するかによって異なります。より多くのコンテキストコードがなければ、問題が何であるかを言うことは困難です。いずれにしても、Observableをサービスに入れることをお勧めします。それはより良い解決策です。 – hholtij