【发布时间】:2019-01-24 22:50:43
【问题描述】:
我添加了一个解析器,以便在用户登录后从 Cloud Firestore 获取用户信息。但是,解析器没有完成,视图也没有被渲染。
import { Injectable } from '@angular/core';
import { Resolve, ActivatedRouteSnapshot } from '@angular/router';
import {
AngularFirestore,
AngularFirestoreCollection,
AngularFirestoreDocument
} from 'angularfire2/firestore';
import {AngularFireAuth} from 'angularfire2/auth';
import { map } from 'rxjs/operators';
@Injectable()
export class LoginUserResolve implements Resolve<any> {
usersCollection: AngularFirestoreCollection<any>;
users: any;
userDoc: AngularFirestoreDocument<any>;
constructor(public afs: AngularFirestore, public afAuth: AngularFireAuth) {
this.usersCollection = this.afs.collection('users');
}
resolve(route: ActivatedRouteSnapshot) {
const email = this.afAuth.auth.currentUser.email;
console.log('Email: ', email);
return this.afs.collection('users', ref => ref.where('email', '==', email)).snapshotChanges().pipe(
map(actions => actions.map(proj => {
const data: any = proj.payload.doc.data();
data.id = proj.payload.doc.id;
return data;
})));
}
}
在控制台日志中,我看到正在记录用户的电子邮件,之后我没有看到来自组件的任何日志。
【问题讨论】:
-
您是否测试过返回是否有效(如果它真的在您订阅时返回数据)?
-
是的,我在向解析器添加日志时看到了数据。我看到了查询返回的文档
-
我遇到了同样的问题。非常令人沮丧。您不能在 resolve 方法中返回尚未完成的 observables。如果您要在地图运算符之后添加 take(1),您可能会发现它有效。不幸的是,您现在有一个与 Firestore 断开连接的死 Observable。我仍在尝试了解将 Firestore 与 Resolver 一起使用的惯用方式是什么。最令人沮丧的是,它默默地失败了。
-
只是添加注释。尝试不要为解析器流式传输数据。使用
get()而不是snapshotChanges()
标签: angular typescript firebase observable google-cloud-firestore