Firestore :检索单个文档
Firestore : Retrieve a single document
我想从 Firestore 中检索单个文档。所以我不是指集合中的文档列表(我知道该怎么做)。假设我知道文档的键值对之一,我想查找文档并将其检索到 Angular 4.
interface Occupations {
duration: number;
id_entity: number;
id_job: number;
id_user: number;
salary: number;
start_time: number;
}
occupationDoc:AngularFirestoreDocument<Occupations>;
occupation: Observable<Occupations>;
<h1>A specific post:</h1>
<h3>{{ (occupation | async)?.salary }}</h3>
<p>{{ (occupation | async)?.id_user }}</p>
<p>{{ (occupation | async)?.duration }}</p>
<p>{{ (user | async)?.lastName }}</p>
使用平面图return单文档数据:
首先导入 .flatMap() 属性.
import { AngularFirestore } from 'angularfire2/firestore';
import 'rxjs/add/operator/mergeMap';
然后查询您的集合并将其限制为 1 个文档:
this.afs.collection('collection', ref => ref.where('value', '==', true)
.limit(1)).valueChanges().flatMap(result => result);
然后您可以订阅它,它将 return 扁平化 json 而不是数组。
编辑:
您可以直接在 html 中使用它:
this.userInfo = this.afs.collection('collection', ref => ref.where('value',
'==', true).limit(1)).valueChanges().flatMap(result => result);
在html代码中:
<p>{{ (userInfo | async)?.duration }}</p>
这是我想出的解决方案:
//HTML
{{userInfo}}
//TypeScript
this.afs.collection('Occupations',
ref => ref.where('id_user', '==', this.idAuth)
.limit(1))
.valueChanges()
.flatMap(result => result)
.subscribe(
v => {
let y = JSON.parse(JSON.stringify(v));
this.userInfo = y.duration;
},
(error) => {
console.log(error);
}, () => {
console.log('Finished');
});
我想从 Firestore 中检索单个文档。所以我不是指集合中的文档列表(我知道该怎么做)。假设我知道文档的键值对之一,我想查找文档并将其检索到 Angular 4.
interface Occupations {
duration: number;
id_entity: number;
id_job: number;
id_user: number;
salary: number;
start_time: number;
}
occupationDoc:AngularFirestoreDocument<Occupations>;
occupation: Observable<Occupations>;
<h1>A specific post:</h1>
<h3>{{ (occupation | async)?.salary }}</h3>
<p>{{ (occupation | async)?.id_user }}</p>
<p>{{ (occupation | async)?.duration }}</p>
<p>{{ (user | async)?.lastName }}</p>
使用平面图return单文档数据:
首先导入 .flatMap() 属性.
import { AngularFirestore } from 'angularfire2/firestore';
import 'rxjs/add/operator/mergeMap';
然后查询您的集合并将其限制为 1 个文档:
this.afs.collection('collection', ref => ref.where('value', '==', true)
.limit(1)).valueChanges().flatMap(result => result);
然后您可以订阅它,它将 return 扁平化 json 而不是数组。
编辑:
您可以直接在 html 中使用它:
this.userInfo = this.afs.collection('collection', ref => ref.where('value',
'==', true).limit(1)).valueChanges().flatMap(result => result);
在html代码中:
<p>{{ (userInfo | async)?.duration }}</p>
这是我想出的解决方案:
//HTML
{{userInfo}}
//TypeScript
this.afs.collection('Occupations',
ref => ref.where('id_user', '==', this.idAuth)
.limit(1))
.valueChanges()
.flatMap(result => result)
.subscribe(
v => {
let y = JSON.parse(JSON.stringify(v));
this.userInfo = y.duration;
},
(error) => {
console.log(error);
}, () => {
console.log('Finished');
});