[英]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.