![](/img/trans.png)
[英]What should I use instead of document.queryselector() when using React?
[英]What should I use instead of toPromise() when using await on an Observable?
这个页面说"toPromise has been deprecated. (RxJS 5.5+)"
但我最近一直在使用它和 AngularFire2(当我只想要一个结果时),如下所示:
const foo = await this.afs.doc(`docPath`).valueChanges().toPromise();
我不应该这样做吗? 如果不是,那么await
替代方案是什么?
更新:
在下面的答案之后,我改变了这个:
const foo = await this.afs.doc(`docPath`).valueChanges().toPromise();
...对此:
const foo = await (new Promise(resolve => this.afs.doc(`docPath`).valueChanges().pipe(first()).subscribe(result => resolve(result))));
有人可以向我解释一下这是如何改进的吗? 对我来说似乎是一个倒退。
你应该放管后!
.pipe(take(1)).toPromise
对于那些想要疯狂的人来说,还有其他一些选择:
const foo = await this.afs.doc(`docPath`).valueChanges().pipe(take(1)).toPromise();
或者
const foo = (await this.afs.doc('docPath').get().toPromise()).data();
或者
const foo = (await this.afs.doc('docPath').get().pipe(take(1)).toPromise()).data();
或者
const foo = (await this.afs.doc('docPath').snapshotChanges().pipe(take(1))
.toPromise()).payload.data();
但最短的是:
const foo = (await this.afs.doc('docPath').ref.get()).data();
在任何可以使用take(1)
的地方,如果你想发出错误,你可以使用first()
。
有关 Firebase 的更多承诺,请参见此处。
Ĵ
firstValueFrom
和lastValueFrom
是更好的选择,原因有很多:
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.