[英]How to return an Observable in angular 4?
我在authProvider
提供程序類中有這個方法:
getUser() {
return this.afAuth.authState.subscribe(user => {
return user;
});
}
我想在不同的課程中訂閱它,例如:
this.authProvider.getUser().subscribe(user => console.log(user));
任何想法如何在getUser()
方法中返回一個Observable
?
您的authState
已經是Observable。 只需返回你的authState
並在另一個函數中訂閱。 在任何其他工作的功能中,您可以使用RxJS #map功能。
getUser() : Observable {
return this.afAuth.authState.map(...);
}
....
login() {
getUser().subscribe(user => {
return user;
});
}
不要在getUser
函數中訂閱。 只需返回可見的東西。
getUser() {
return this.afAuth.authState
}
你可以做這樣的事情。 然后在您的組件中,調用此函數的組件,您可以訂閱此observable。
getUser(): Observable<any> {
return Observable.create( (observer: Observer<string>) => {
this.afAuth.authState.subscribe(user => {
observer.next(user);
}, (err) => observer.error("error"));
});
}
阿什利
您需要將返回類型設置為observable
getUser(): Observable<Type> {
return this.afAuth.authState;
});
}
您可以直接返回該函數並在另一個類中訂閱它。
getUser() {
return this.afAuth.authState();
}
您可以將observable視為訂閱調用的函數。
this.authProvider.getUser().subscribe(user => console.log(user));
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.