将数据从 FirebaseListObservable 提取到 Array



对不起我的英语,我有这个可观察的:

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它即可创建其他可观察量,就像我们上面所做的那样,创建键数组的可观察量,或者订阅它以获取基础数据。

相关内容

  • 没有找到相关文章

最新更新