如何动态向Firestore查询添加参数并映射到对象

问题描述 投票:0回答:1

将数据映射到对象并以promise / observable形式返回它,同时能够向查询中添加动态/条件参数的推荐方法是什么。

在getCompanies2中,我可以向查询中动态添加参数,但是我不知道如何映射返回到我的对象的数据并将其作为promise / observable返回。

在getCompanies中,一切都按我的要求运行,但是如果要添加动态查询参数,则必须重复代码(如下所示)。>

注意:convertDocTimeStampsToDate只是按照它说的做。我已排除它,以减少代码部分的大小。

getCompanies(searchText: string, useWhereActive: boolean): Observable<Company[]> {
    if (useWhereActive) {
      return this.db.collection('companies', ref => ref
      .orderBy('name').startAt(searchText).endAt(searchText + '\uf8ff')
      .where('active', '==', true)
    )
      .snapshotChanges()
      .pipe(
        map(snaps => convertSnaps<Company>(snaps)),
        first()
      );
    } else {
      return this.db.collection('companies', ref => ref
      .orderBy('name').startAt(searchText).endAt(searchText + '\uf8ff')
    )
      .snapshotChanges()
      .pipe(
        map(snaps => convertSnaps<Company>(snaps)),
        first()
      );
    }
  }
​
getCompanies2(searchText: string, useWhereActive: boolean) {
    let query = this.db.collection('companies').ref
      .orderBy('name').startAt(searchText).endAt(searchText + '\uf8ff');
​
    if (useWhereActive) {
      query.where('active', '==', true);
    }
​
    query.get().then(querySnapshot => {
      const results = this.convertDocuments<Company>(querySnapshot.docs);
      console.log(results);
    });
}


convertDocuments<T>(docs) {
    return <T[]>docs.map(doc => {
      return {
        id: doc.id,
        ...doc.data()
      };
    });
}

export function convertSnaps<T>(snaps) {
  return <T[]>snaps.map(snap => {
    const data = convertDocTimeStampsToDate(snap.payload.doc.data());
    return {
      id: snap.payload.doc.id,
      ...data
    };
  });
}

将数据映射到对象并将其作为promise / observable返回的建议方法,同时又可以向查询中添加动态/条件参数。在getCompanies2中,我可以动态地...

google-cloud-firestore angularfire2
1个回答
0
投票

我让它像下面那样工作,我想我仍然会兑现承诺。

© www.soinside.com 2019 - 2024. All rights reserved.