【发布时间】:2018-06-26 15:35:44
【问题描述】:
我有一个输出 2 个 observables 的服务。 1 只用于获取当前经过身份验证的用户,另一个用于获取所有活动用户。在主屏幕上,我想调用这两个 observables 来使用,这将(当前)通过订阅这两个 observables 来完成,但是第一个 observables 并不总是运行。我正在寻找一种解决方案,让这两个可观察对象在我们或页面上加载任何错误之前发出一个值。我在下面的示例中尝试了 forkjoin,但它不起作用,我怀疑这是因为 forkjoin 期望发出一些东西但没有发出任何东西,但是订阅两个 observables 确实输出了我需要的数据。这是我尝试过的:
const tt = Observable.forkJoin(
this.auth.getActiveUsers().map((res) => res = res ),
this.auth.user.map((res) => res = res ),
);
console.log("running" );
tt.subscribe( (data) => {
console.log("data ", data );
console.log("data[0] ", data[0] );
console.log("data[1] ", data[1] );
},
err => console.error(err),
() => console.error("complete"),
);
这是订阅在我的 service.ts 文件中的布局方式:
Filename: Service.ts
...
// first Observable
constructor( private afAuth: AngularFireAuth,
private db: AngularFirestore ) {
this.user = this.afAuth.authState.switchMap(user => {
if (user) {
return this.db.doc<iUser>(`users/${user.uid}`).valueChanges()
} else {
return Observable.of(null)
}
})
}
...
// second Observable
getActiveUsers(): Observable<iUser[]> {
return this.db.collection<iUser>('users').valueChanges().catch(this.catchError);
}
...
【问题讨论】:
标签: javascript angular ionic-framework rxjs ionic3