gpt4 book ai didi

javascript - 转换 RxJS Observable

转载 作者:太空狗 更新时间:2023-10-29 17:56:08 24 4
gpt4 key购买 nike

我使用 angularFirestore 在 firebase 上查询,我想使用 DocumentReference 连接来自多个文档的数据。

管道中的第一个运算符映射返回一个 IOrderModelTable 数组,第二个运算符,即 switchMap 遍历数组,并为每个元素使用每个元素中包含的 id 来查询其他表中的数据。

问题是在 swithMap 中,我获得了一个 observable 数组,这是由于 anidated map operators。如何获取 IOrderModelTable 数组,然后返回该数组的可观察对象。

代码是:

getDataTableOperatorsFromDB(): Observable<IOrderModelTable[]> {
const observable = this.tableOperatorsCollectionsRef.snapshotChanges().pipe(
map(actions => {
return actions.map(a => {
const data = a.payload.doc.data() as IOrdersModelDatabase;
const id = a.payload.doc.id;

data.ot = id;
return data;
});
}),
switchMap(data => {
const result = data.map(element => {
return this.afs.collection('Orders/').doc(element.orderNumberReference.id).valueChanges().pipe(map(order => {
return {
otNumber: element.ot,
clientName: '',
clientReference: order.clientReference,
id: element.orderNumberReference,
};
}));
});

// Result must be an IOrderModelTable[] but is a Observable<IOrderModelTable>[]

return of(result);
})
);

最佳答案

您可以使用 to Array运算符将流转换为数组,但要确保流将结束。诀窍在于选择正确的流。

对于您的问题,自然 源将是您第一次调用时收到的列表。我可以用一种示意性的方式来表示,你会得到一个 id 列表,然后将其转换为一个增强信息列表:

首先输入...snapshopChanges():

----[A, B, C]------>

每个元素都通过...valueChanges()进行转换:

-------Call A -------------DataA-------->

-------Call B ------------------------DataB----->

-------Call C --------------------DataC----->

然后使用 toArray() 减少到:

----------------------------------------------[DataA, DataC, DataB]-------->

代码:

getDataTableOperatorsFromDB(): Observable<IOrderModelTable[]> { {
return this.tableOperatorsCollectionsRef.snapshotChanges()
.pipe(
map(actions => {
from(data).pipe(
map(action => {
const data = a.payload.doc.data() as IOrdersModelDatabase;
const id = a.payload.doc.id;
data.ot = id;
return data;
}),
mergeMap(element => {
return this.afs.collection('Orders/').doc(element.orderNumberReference.id).valueChanges().pipe(
map(order => {
return {
otNumber: element.ot,
clientName: '',
clientReference: order.clientReference,
id: element.orderNumberReference,
};
})
);
}),
toArray()
);

})
)
}

重要:我用mergeMap替换了switchMap,否则一些信息可能会被丢弃。

关于javascript - 转换 RxJS Observable,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52890515/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com