ValueEventListener vs ChildEventListener for RecyclerView in Android
Firebase 数据库用户知道有两个用于侦听 Data 的基本侦听器:和 。当我们听一个对象时,它效果很好,但是当我们听一些集合时,它会变得非常困难。ValueEventListener
ChildEventListener
为了指定问题,让我们想象一下我们有HackerNews提要,我们听例如Firebase中的“posts”对象。
当然,我们的应用程序中有用于显示帖子的好主意,我认为使用FirebaseUI是个好主意,但问题是,我们希望在更改服务器端或测试的情况下制作更抽象的应用程序。因此,我们将使用一些适配器,但这是另一个问题。RecyclerView
正如我所提到的,我们有两个听众,问题是哪个更好?
当我们使用时,我们将获得整个集合,但是如果发生任何更改,例如一个用户更改了帖子的内容,我们将不得不重新加载整个数据,这意味着通过昂贵的网络传输发送更多的字节。另一个问题是当我们使用多列表器时,下面是一个例子:ValueEventListener
Post有userId,但我们想显示他的名字,所以在方法中我们获取用户数据,如下所示:onDataChanged
postsReference.addValueEventListener(new ValueEventListener() {
@Override
public void onDataChange(DataSnapshot dataSnapshot) {
for (DataSnapshot data : dataSnapshot.getChildren()) {
Post post = data.getValue(Post.class);
usersReference.child(post.getUserId()).addListenerForSingleValueEvent(new ValueEventListener() {
@Override
public void onDataChange(DataSnapshot dataSnapshot) {
// Here we have user data
}
@Override
public void onCancelled(FirebaseError firebaseError) {
}
});
}
}
@Override
public void onCancelled(FirebaseError firebaseError) {
}
});
您可以看到,现在我们必须单独添加每个帖子,这将为我们提供线索,也许我们应该使用 。RecyclerView
ChildEventListener
所以现在当我们使用“ChildEventListener”时,问题是一样的 - 我们必须单独添加每个帖子,但是当有人更改帖子内容时,firebase只向我们发送这一个帖子,这意味着通过网络的数据更少。RecyclerView
我们不喜欢将帖子单独添加到 ,因为例如: - 很难添加加载指标,因为我们不知道何时所有数据都出现。- 用户获得不断刷新的视图,而新帖子出现而不是整个列表变得可见。- 很难对该集合进行排序,我们可能必须在适配器中执行此操作。RecyclerView
问题
将 firebase 与集合一起使用的最佳实践是什么,也许比我上面写的更好的解决方案?
编辑
数据方案将如下所示:
"posts" : {
"123456" : {
"createdAt" : 1478696885622,
"content" : "This is post content",
"title" : "This is post title",
"userId" : "abc"
},
"789012" : {
"createdAt" : 1478696885622,
"content" : "This is post content 2",
"title" : "This is post title 2",
"userId" : "efg"
}
}
"users" : {
"abc" : {
"name" : "username1"
},
"efg" : {
"name" : "username2"
}
}
编辑 2
我犯了一个错误 - >当某些东西发生变化时,Firebase不会获取整个数据。它只得到“delta”,这是证据。ValueEventListener