Firestore-我想向集合中动态添加where语句

时间:2019-02-12 22:00:33

标签: angular firebase google-cloud-firestore geofire geofirestore

技术:我正在使用Angular 7,Firestore,GeoFireX。

我想要的结果:如果用户需要该查询,我想添加.where查询。例如,下面有四个.wheres。有时我可能只需要两个,因此如果用户按行业和品牌进行搜索,则只想使用if语句添加两个(请参见方法:basicQueryBuilder)

下面的代码有效,但不是动态的。

此外,GeoFireX的this.geo.collection是否可以像普通集合一样具有.limit(20)?

当前尝试:

  public getFirestoreJobs(queryType: string, limit: number, pageSize: number): Observable<any> {
    limit = limit + pageSize;

    if (queryType === 'geo') {
      const collection = this.geoQueryBuilder();
      const center = this.geo.point(51.5074, 0.1278);
      const radius = 20;

      return collection.within(center, radius, 'point');
    } else {
      const collection = this.basicQueryBuilder();

      return collection.valueChanges();
    }
  }

  public geoQueryBuilder(): any  {
    return this.geo.collection('jobs', ref => ref
      .where('sector', '==', 'teacher')
      .where('brand', '==', 'all')
      .where('payType', '==', 'salary')
      .where('tags', 'array-contains', 'salary'));
  }

  public basicQueryBuilder(): any {
    return this.angularFirestore.collection('jobs', ref => ref
      .where('sector', '==', 'teacher')
      .where('brand', '==', 'all')
      .where('payType', '==', 'salary')
      .where('tags', 'array-contains', 'salary').limit(20));
  }

第二次尝试:

  let query = this.angularFirestore.collection('jobs');
  query = query.where('sector', '==', 'teacher');
  query = query.where('brand', '==', 'all');

  return query.valueChanges();

我收到错误:

错误TS2322:“查询”类型无法分配给“ CollectionReference”类型。

1 个答案:

答案 0 :(得分:0)

import {Query, QueryFn } from '@angular/fire/firestore';

    this.angularFirestore.collection('jobs', ref => {
    let query : Query = ref;
    if(condition1) {
     query = query.where('sector', '==', 'teacher');
    }
    if(condition2) {
     query = query.where('brand', '==', 'all');
    }
    return query;
    })