我怎样才能限制到最后的orderByChild?

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

我需要做的是基本上获得最后50的前十名。或者字面上限制ToLast(50)那么orderByChild。

现在,这段代码可以很好地获取我的整个列表中的前50个(数千个)并将其反转以获得正确的显示顺序,但它会对整个列表进行排序并返回前50个。我需要对最后50个条目中的前10个进行排序。

export class DisplayComponent{
  trackFbObjects = (idx, obj) => obj.$key;

  fml: Observable<any>

  constructor(db: AngularFireDatabase) {    
    this.fml = db.list('vertigo', ref => ref.limitToLast(50).orderByChild("totalvote")).valueChanges()
    .map((Array) => Array.reverse());
  }

}

然后我将使用NgFor和NgIf将50中的10个拉出来:

<ul *ngFor="let item of (fml | async); let i = index; trackBy:trackFbObjects">
<li *ngIf="i<10"> {{ item.title }}  </li></ul>

我想也许有可能只做limitToLast(50)然后在Array.reverse()期间可能用“totalvote”对它进行排序?我不知道,但我找不到工作的解决方案,任何帮助将不胜感激。

如果有帮助,我的条目看起来像这样:

     vertigo
       -L9X0AiwPemOIepVm5gf
         -totalvote: "333"
         -title: "Smile."
firebase firebase-realtime-database angularfire2
1个回答
0
投票

如果将来有人需要这个,我能够在我的查询之外对我的列表进行排序,如下所示:

  constructor(db: AngularFireDatabase) {    
    this.fml = db.list('vertigo', ref => ref.limitToLast(50)).valueChanges()
    .map((Array) => Array.sort((a, b) => b['totalvote'] - a['totalvote']));
  }
© www.soinside.com 2019 - 2024. All rights reserved.