我已经运行我的应用程序完美地与
“@angular/fire”:“^6.1.5”,
“火线”:“^8.6.3”,
就像是
Service.ts
getUserEventSummary(userId) {
this.firestore.collection(`/user/${userId}/event_summary`).doc('current').snapshotChanges().pipe(
map(changes => changes.payload.data())
);
}
Component.ts
this.service.getUserEventSummary(this.userId).subscribe((res: any) => {
this.values = res;
}
而且这样的代码遍布应用程序,现在我已经移到了最新版本的firebase也就是
“火线”:“^9.0.1”,“Angular /火线”:“^7.0.4”,
新的变化是
service.ts
getUserEventSummary(userId) {
return onSnapshot(doc(db, 'general_lookup', 'onboarding_page'), (document) => {
return document.data();
});
}
和组件。ts
const data = this.homeService.getOnboaringCollection();
console.log(data);
但我在控制台上什么也没有得到。
按照这里所描述的,看起来我必须在组件文件中管理它。它是使用onSnapshot
的唯一选项吗?
请帮助我一个更好的方法比改变组件的代码。
1条答案
按热度按时间g6ll5ycj1#
经过大量的挖掘,我能够找到以下解决方案,它将允许您以类似于
snapshotChanges
以前的方式返回快照。服务:
组件:
不幸的是,文档并不像它可能的那样清晰或深入,因为Firebase 9仍然很新,但随着时间的推移,它肯定会改进。