gpt4 book ai didi

javascript - Firebase - 动态或更改 orderByChild 变量

转载 作者:行者123 更新时间:2023-12-03 02:22:58 27 4
gpt4 key购买 nike

我有两种方式对数据库表进行排序。

第一个是按日期(在我的情况下是创建),第二个是按得分

所以我有一个下拉菜单,用户可以在其中指定他们想要排序的依据,并且我有一个调用正确数据库引用的函数。

 goToNew() {
this.postFeed = [];
this.database.database.ref('/posts/'+this.location)
.orderByChild('created')
.startAt(new Date().getTime() - (24 * 3600 * 1000)) //last 24hrs
.limitToLast(10)
.on('child_added', (snapshot) => {
this.postFeed.push(snapshot.val())
});
}

goToHot() {
this.postFeed = [];
this.database.database.ref('/posts/'+this.location)
.orderByChild('score')
.startAt(new Date().getTime() - (24 * 3600 * 1000)) //last 24hrs
.limitToLast(10)
.on('child_added', (snapshot) => {
this.postFeed.push(snapshot.val())
});
}

我有两个问题:

  1. 在每个 database.ref 之间切换会导致内存泄漏。如果您在两个设置之间切换几次并添加新帖子,它会多次显示该帖子......这很奇怪

  2. 我更愿意在 orderByChild 之间动态切换,因为这是唯一不同的地方。

有人有更好的解决方案来解决我的问题吗?谢谢!

最佳答案

查询是不可变的。一旦创建了具有特定排序顺序的查询,就无法对其进行修改。因此,无法动态更改查询的排序顺序。

Switching between each database.ref causes memory leaks.

如果您能分享您是如何确定这一点的,那就太好了。但很可能是因为您没有删除以前的监听器。您可以remove the listener通过在查询上调用 off() :

let query = this.database.database.ref('/posts/'+this.location)
.orderByChild('created')
.startAt(new Date().getTime() - (24 * 3600 * 1000)) //last 24hrs
.limitToLast(10);
query.on('child_added', (snapshot) => {
this.postFeed.push(snapshot.val())
});

然后:

query.off();

或者跟踪监听器:

var listener = query.on('child_added', (snapshot) => {
this.postFeed.push(snapshot.val())
});

然后:

query.off(listener);

关于javascript - Firebase - 动态或更改 orderByChild 变量,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49076432/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com