Firestore如何从另一个集合文档id中获取集合值被引用
Firestore how to get the collection value from another collection document id is referenced
我有两个 fire store 系列,参考图片如下
.
我想获得 firstName 和 title。这里 signup_id 引用自 coll-signup 文档 ID。按照下面给出的代码我做了什么。
型号feed.ts
export interface Feed {
firstName? : string;
signup_id? : string;
title? : string;
}
新闻feed.component模板
<ul *ngFor="let feed of feeds">
<!-- <li>{{feed.firstName}}</li> --> // Here I want to print my first name
<li>{{feed.title}}</li>
<li>{{feed.signup_id}}</li>
</ul>
新闻-feed.component.ts
import { Component, OnInit } from '@angular/core';
import { Feed } from '../../models/feed';
import { FeedService } from '../../services/feed.service';
@Component({
selector: 'app-news-feed',
templateUrl: './news-feed.component.html',
styleUrls: ['./news-feed.component.css']
})
export class NewsFeedComponent implements OnInit {
feeds : Feed[];
constructor(private feedService: FeedService) { }
ngOnInit() {
this.feedService.sellectAllNews().subscribe(feeds => {
this.feeds = feeds;
})
}
}
feed.service.ts
import { AngularFirestore, AngularFirestoreCollection, AngularFirestoreDocument } from 'angularfire2/firestore';
import { Observable } from 'rxjs/Observable';
import { Feed } from '../models/feed';
@Injectable()
export class FeedService {
feedCollection : AngularFirestoreCollection<Feed>;
feedItem : Observable<Feed[]>;
constructor(private afs : AngularFirestore) {
this.collectionInitialization();
}
collectionInitialization() {
// I think here I have to modify or add next collection to will get the output
this.feedCollection = this.afs.collection('col-challange');
this.feedItem = this.feedCollection.stateChanges().map(changes => {
return changes.map(a => {
const data = a.payload.doc.data() as Feed;
return data;
})
})
}
sellectAllNews() {
this.collectionInitialization();
return this.feedItem;
}
}
这可以做fire store吗?
我是 fire 的新手 store.Please 帮助我。谢谢!
您需要合并两个集合。
试试这个代码
this.feedCollection = this.afs.collection('col-challange');
this.feedItem = this.feedCollection.snapshotChanges().map(changes => {
return changes.map(a => {
//here you get the data without first name
const data = a.payload.doc.data() as Feed;
//get the signup_id for getting doc from coll-signup
const signupId = data.signup_id;
//get the related document
return afs.collection('coll-signup').doc(signupId).snapshotChanges().take(1).map(actions => {
return actions.payload.data();
}).map(signup => {
//export the data in feeds interface format
return { firstName: signup.firstName, ...data };
});
})
}).flatMap(feeds => Observable.combineLatest(feeds));
对于遇到问题的任何人,在使用 Angular6、RxJS 6 和 AngularFire v5.0 时在 Firebase Cloud Firestore 中合并文档尝试以下操作代码
型号feed.ts
export interface Feed {
firstName?: string;
signup_id?: string;
title?: string;
}
export interface CollSignup {
firstName: string;
mob: string;
}
export interface ColChallange {
signup_id: string;
title: string;
}
服务feed.service.ts
import { AngularFirestore, AngularFirestoreCollection } from '@angular/fire/firestore';
import { Observable, combineLatest } from 'rxjs';
import {flatMap, map} from 'rxjs/operators';
import {ColChallange, CollSignup, Feed} from '../../models/feed';
@Injectable()
export class FeedService {
colChallangeCollection: AngularFirestoreCollection<ColChallange>;
feedItem: Observable<Feed[]>;
constructor(private afs: AngularFirestore) { }
collectionInitialization() {
this.colChallangeCollection = this.afs.collection('col-challange');
this.feedItem = this.colChallangeCollection.snapshotChanges().pipe(map(changes => {
return changes.map( change => {
const data = change.payload.doc.data();
const signupId = data.signup_id;
const title = data.title;
return this.afs.doc('coll-signup/' + signupId).valueChanges().pipe(map( (collSignupData: CollSignup) => {
return Object.assign(
{firstName: collSignupData.firstName, signup_id: signupId, title: title}); }
));
});
}), flatMap(feeds => combineLatest(feeds)));
}
sellectAllNews() {
this.collectionInitialization();
return this.feedItem;
}
}
打印所有数据
this.feedItem.forEach(value => {
console.log(value);
});
我有两个 fire store 系列,参考图片如下
.
型号feed.ts
export interface Feed {
firstName? : string;
signup_id? : string;
title? : string;
}
新闻feed.component模板
<ul *ngFor="let feed of feeds">
<!-- <li>{{feed.firstName}}</li> --> // Here I want to print my first name
<li>{{feed.title}}</li>
<li>{{feed.signup_id}}</li>
</ul>
新闻-feed.component.ts
import { Component, OnInit } from '@angular/core';
import { Feed } from '../../models/feed';
import { FeedService } from '../../services/feed.service';
@Component({
selector: 'app-news-feed',
templateUrl: './news-feed.component.html',
styleUrls: ['./news-feed.component.css']
})
export class NewsFeedComponent implements OnInit {
feeds : Feed[];
constructor(private feedService: FeedService) { }
ngOnInit() {
this.feedService.sellectAllNews().subscribe(feeds => {
this.feeds = feeds;
})
}
}
feed.service.ts
import { AngularFirestore, AngularFirestoreCollection, AngularFirestoreDocument } from 'angularfire2/firestore';
import { Observable } from 'rxjs/Observable';
import { Feed } from '../models/feed';
@Injectable()
export class FeedService {
feedCollection : AngularFirestoreCollection<Feed>;
feedItem : Observable<Feed[]>;
constructor(private afs : AngularFirestore) {
this.collectionInitialization();
}
collectionInitialization() {
// I think here I have to modify or add next collection to will get the output
this.feedCollection = this.afs.collection('col-challange');
this.feedItem = this.feedCollection.stateChanges().map(changes => {
return changes.map(a => {
const data = a.payload.doc.data() as Feed;
return data;
})
})
}
sellectAllNews() {
this.collectionInitialization();
return this.feedItem;
}
}
这可以做fire store吗? 我是 fire 的新手 store.Please 帮助我。谢谢!
您需要合并两个集合。
试试这个代码
this.feedCollection = this.afs.collection('col-challange');
this.feedItem = this.feedCollection.snapshotChanges().map(changes => {
return changes.map(a => {
//here you get the data without first name
const data = a.payload.doc.data() as Feed;
//get the signup_id for getting doc from coll-signup
const signupId = data.signup_id;
//get the related document
return afs.collection('coll-signup').doc(signupId).snapshotChanges().take(1).map(actions => {
return actions.payload.data();
}).map(signup => {
//export the data in feeds interface format
return { firstName: signup.firstName, ...data };
});
})
}).flatMap(feeds => Observable.combineLatest(feeds));
对于遇到问题的任何人,在使用 Angular6、RxJS 6 和 AngularFire v5.0 时在 Firebase Cloud Firestore 中合并文档尝试以下操作代码
型号feed.ts
export interface Feed {
firstName?: string;
signup_id?: string;
title?: string;
}
export interface CollSignup {
firstName: string;
mob: string;
}
export interface ColChallange {
signup_id: string;
title: string;
}
服务feed.service.ts
import { AngularFirestore, AngularFirestoreCollection } from '@angular/fire/firestore';
import { Observable, combineLatest } from 'rxjs';
import {flatMap, map} from 'rxjs/operators';
import {ColChallange, CollSignup, Feed} from '../../models/feed';
@Injectable()
export class FeedService {
colChallangeCollection: AngularFirestoreCollection<ColChallange>;
feedItem: Observable<Feed[]>;
constructor(private afs: AngularFirestore) { }
collectionInitialization() {
this.colChallangeCollection = this.afs.collection('col-challange');
this.feedItem = this.colChallangeCollection.snapshotChanges().pipe(map(changes => {
return changes.map( change => {
const data = change.payload.doc.data();
const signupId = data.signup_id;
const title = data.title;
return this.afs.doc('coll-signup/' + signupId).valueChanges().pipe(map( (collSignupData: CollSignup) => {
return Object.assign(
{firstName: collSignupData.firstName, signup_id: signupId, title: title}); }
));
});
}), flatMap(feeds => combineLatest(feeds)));
}
sellectAllNews() {
this.collectionInitialization();
return this.feedItem;
}
}
打印所有数据
this.feedItem.forEach(value => {
console.log(value);
});