我知道你在这里得到了一个有效的答案:https : //github.com/angular/angularfire2/issues/1567
测试:“angularfire2”:“^5.0.0-rc.6.0”,“firebase”:“^4.12.1”
我已经构建了一个受我想分享的 #1567 启发的极简包装。有两种方法可以在不同或相同的项目中使用多个数据库。
您可能会使用第一个,我真的不明白在多个项目中使用多个数据库的意义。
@Injectable()
export class AngularFireWrapper {
// Default database
private _firebaseDb = this.afDb.database;
constructor(private afDb: AngularFireDatabase,
@Optional() dbName: string) {
console.log('Hello AngularFireWrapper, db :', dbName || 'default');
// 1st Method, same project, same auth
// environment.dbUrls = {
// ...
// otherDb: 'https://DB_NAME_SAME_PROJECT.firebaseio.com/'
// }
if (dbName && environment.dbUrls[dbName]) {
const app: any = this.afDb.app;
this._firebaseDb = app.database(environment.dbUrls[dbName]);
}
// 2nd Method, other project, different auth =/
// environment.dbConfigs = {
// ...
// otherDb: {...} // usual firebase configs
// }
if (dbName && environment.dbConfigs[dbName]) {
this._firebaseDb = firebase.initializeApp(environment.dbConfigs[dbName], dbName)
.database();
}
}
db(dbName): AngularFireWrapper {
return new AngularFireWrapper(this.afDb, dbName);
}
object(path: string): AngularFireObject<any> {
const ref = this._firebaseDb.ref(path);
return this.afDb.object(ref);
}
list(path: string, queryFn?: QueryFn): AngularFireList<any> {
const ref = this._firebaseDb.ref(path);
return this.afDb.list(ref, queryFn);
}
}
复制粘贴,像通常使用自定义服务一样注入它,然后:
export class MyApp {
constructor(private afW: AngularFireWrapper) {
this.afW.object('test')
.valueChanges()
.subscribe(console.log)
// => output default db values
this.afW.db('otherDb').object('test')
.valueChanges()
.subscribe(console.log)
// => output otherDb values
}
本文收集自互联网,转载请注明来源。
如有侵权,请联系[email protected] 删除。
我来说两句