我正在将Ionic3与rxjs / Observable一起使用.我有以下函数,由于某种原因,即使该函数仅被调用一次,第三行也会被触发两次.
findChats(): Observable<any[]> {
return Observable.create((observer) => {
this.chatSubscription2 = this.firebaseDataService.findChats().subscribe(firebaseItems => {
this.localDataService.findChats().then((localItems: any[]) => {
let mergedItems: any[] = [];
if (localItems && localItems != null && firebaseItems && firebaseItems != null) {
for (let i: number = 0; i < localItems.length; i++) {
if (localItems[i] === null) {
localItems.splice(i, 1);
}
}
mergedItems = this.arrayUnique(firebaseItems.concat(localItems), true);
} else if (firebaseItems && firebaseItems != null) {
mergedItems = firebaseItems;
} else if (localItems && localItems != null) {
mergedItems = localItems;
}
mergedItems.sort((a, b) => {
return parseFloat(a.negativtimestamp) - parseFloat(b.negativtimestamp);
});
observer.next(mergedItems);
this.checkChats(firebaseItems, localItems);
});
});
});
}
问题
这引起了一个问题,因为this.chatSubscription2正在获取第二个订阅的值,并且第一个订阅丢失了,不允许我取消订阅.
line 2 is executed once
line 3 is executed twice
题
如何创建仅一个订阅的Observable?
谢谢
更新
我使用share()将代码更改为以下代码,但是第三行仍然执行两次:
findChats(): Observable<any[]> {
return Observable.create((observer) => {
const obs = this.firebaseDataService.findChats().share();
this.chatSubscription2 = obs.subscribe(firebaseItems => {
....
解决方法:
正如其他用户所建议的那样,虽然findChats仅被调用一次,但它返回的可观察对象似乎已被预订多次. create返回一个可观察到的冷信号,这将导致对每个预订执行所有内部逻辑.您可以在整个过程的末尾(例如,在create调用之后/之后)进行共享以测试这一点,但是我建议如果您根本不使用create而是仅使用map / flatMapped,则解决方案实际上会更简单/ switch将原始流映射到所需的流中(以避免手动订阅管理).