对不起我的英语,我有这个可观察的:
this.productos = af.database.list('/productos', {
query: {
orderByChild: 'categoria',
equalTo: this.catnombre
}
});
我需要从这里提取所有 id 并设置在一个数组中,但我不知道如何,谢谢。
编辑:
我可以提取id,但我使用de key,现在我需要提取其他数据,但是snapshot.val不起作用。
this.productos = af.database.list('/productos/', {
query: {
orderByChild: 'categoria',
equalTo: this.catnombre
}, preserveSnapshot:true
});
this.productos.subscribe(snapshot => {
snapshot.forEach(snapshot => {
console.log(snapshot.key);
this.idproductos.push(snapshot.key);
});
console.log(this.idproductos);
});
您需要做的就是
this.productos = af.database.list('/productos/', {
query: {
orderByChild: 'categoria',
equalTo: this.catnombre
})
.map(products => products.map(product => product.$key));
结果将是键数组的可观察对象。现在,您可以订阅它或执行任何其他您想做的事情。
this.productos.subscribe(keys => console.log("keys are", keys));
如果正确使用AngularFire和FirebaseListObservable
之类的东西,则无需担心快照,或拍摄它们的val()
,或对它们执行forEach
,或获取元素并将它们放入您自己的数组中。FirebaseListObservable
是数组的可观察对象。只需map
它即可创建其他可观察量,就像我们上面所做的那样,创建键数组的可观察量,或者订阅它以获取基础数据。