Angularfire - 如何使用snapshotChanges()应用'where'条件 Angularfire是一个用于Angular应用的库,它提供了一些与Firebase集成的功能。其中一个功能是使用snapshotChanges()方法来监听
创始人
2024-10-24 19:01:42
0
import { AngularFirestore, AngularFirestoreCollection } from '@angular/fire/firestore';
import { Observable } from 'rxjs';
import { map } from 'rxjs/operators';

constructor(private firestore: AngularFirestore) {}

getFilteredData(): Observable {
  const collection: AngularFirestoreCollection = this.firestore.collection('collectionName', ref => ref.where('field', '==', 'condition'));

  return collection.snapshotChanges().pipe(
    map(actions => {
      return actions.map(a => {
        const data = a.payload.doc.data();
        const id = a.payload.doc.id;
        return { id, ...data };
      });
    })
  );
}

在上面的代码中,我们首先导入AngularFirestore和AngularFirestoreCollection服务,并在构造函数中注入AngularFirestore。

然后,我们使用collection()方法来获取Firestore集合的引用,并传递一个回调函数给它。在回调函数中,我们使用where()方法来设置筛选条件。在这个例子中,我们筛选出字段值等于'condition'的文档。

接下来,我们将snapshotChanges()方法应用于集合引用,并使用pipe()方法将其转换为可观察对象。

在pipe()方法中,我们使用map()操作符来处理每个文档的快照。在这个例子中,我们通过使用map()操作符来遍历每个快照,并返回一个包含文档ID和数据的新对象。

最后,我们返回过滤后的文档集合作为Observables。

相关内容

热门资讯

五分钟透明!博乐温州棋牌有没有... 这是一款非常优秀的博乐温州棋牌有没有挂 ia辅助检测软件,能够让你了解到博乐温州棋牌有没有挂中牌率当...
六分钟辅助挂!博雅红河棋盘外挂... 1、六分钟辅助挂!博雅红河棋盘外挂,微扑克智能助手(详细透视辅助挂教程);详细教程。2、博雅红河棋盘...
6分钟黑科技!友友邳州麻将辅助... 6分钟黑科技!友友邳州麻将辅助器,微扑克靠谱(详细透视辅助软件教程);实战中需综合运用上述技巧,并根...
4分钟攻略!传送屋有外 挂,德... 4分钟攻略!传送屋有外 挂,德扑之星记分牌有有用(详细透视辅助挂教程);传送屋有外 挂黑科技是一款具...
5分钟了解!浙江游戏大厅辅具器... 5分钟了解!浙江游戏大厅辅具器,来玩app辅助工具(详细透视辅助器教程);(需添加指定薇757446...
7分钟介绍!广东雀神辅助器怎么... 7分钟介绍!广东雀神辅助器怎么买,微扑克职业代打(详细透视辅助助手教程);亲,其实确实真的有挂(需添...
三分钟攻略!可乐斗地主有没有挂... 三分钟攻略!可乐斗地主有没有挂,智星德州菠萝在哪下载(详细透视辅助神器教程);可乐斗地主有没有挂黑科...
九分钟规律!花花生活圈脚本,云... 九分钟规律!花花生活圈脚本,云扑克有辅助软件(详细透视辅助软件教程);(需添加指定薇75744690...
七分钟总结!中至窝龙必赢攻略,... 相信很多朋友都在电脑上玩过中至窝龙必赢攻略吧,但是很多朋友都在抱怨用电脑玩起来不方便。为此小编给大家...
1分钟详情!六瓣数字消有没有挂... 1分钟详情!六瓣数字消有没有挂,cloudpoker辅助器(详细透视辅助工具教程)关于六瓣数字消有没...