使用新的分页库时,更新单个元素的最佳方式是什么?
假设我们有Paging with network google 示例,使用PageKeyedSubredditDataSource
. 想象一下,我们想要更改RedditPost
. 因此,我们要检查它是否在列表中,如果是,则更新它。更新不应该像调用 invalidate() 那样简单,它将调用第一页(可能 RedditPost 在第 5 页。我们不想更新所有元素,只更新一个)。
使用新的分页库时,更新单个元素的最佳方式是什么?
假设我们有Paging with network google 示例,使用PageKeyedSubredditDataSource
. 想象一下,我们想要更改RedditPost
. 因此,我们要检查它是否在列表中,如果是,则更新它。更新不应该像调用 invalidate() 那样简单,它将调用第一页(可能 RedditPost 在第 5 页。我们不想更新所有元素,只更新一个)。
请注意,所有这些都适用于Paging with network google 示例。尽管如此,这个想法是存在的。
@Sarquella 帮助我解决了这个问题。将此类添加到您的项目中。基本上我们正在扩展ViewHolder
为 be LifeCycle Owner
,因为默认情况下已经使用Activities
and完成了Fragments
。
LifecycleViewHolder
:_
abstract class LifecycleViewHolder(itemView: View) :
RecyclerView.ViewHolder(itemView),
LifecycleOwner {
private val lifecycleRegistry = LifecycleRegistry(this)
fun onAttached() {
lifecycleRegistry.handleLifecycleEvent(Lifecycle.Event.ON_START)
}
fun onDetached() {
lifecycleRegistry.handleLifecycleEvent(Lifecycle.Event.ON_STOP)
}
override fun getLifecycle(): Lifecycle = lifecycleRegistry
}
LifecycleOwner
是单个方法接口,表示该类具有Lifecycle
. 您可以在此处找到更多信息。
LifecyclePagedListAdapter
:_
abstract class LifecyclePagedListAdapter<T, VH : LifecycleViewHolder>(diffCallback: DiffUtil.ItemCallback<T>) :
PagedListAdapter<T, VH>(diffCallback) {
override fun onViewAttachedToWindow(holder: VH) {
super.onViewAttachedToWindow(holder)
holder.onAttached()
}
override fun onViewDetachedFromWindow(holder: VH) {
super.onViewDetachedFromWindow(holder)
holder.onDetached()
}
}
(在您需要的LifecycleAdapter
情况下):
abstract class LifecycleAdapter<VH : LifecycleViewHolder> :
RecyclerView.Adapter<VH>() {
override fun onViewAttachedToWindow(holder: VH) {
super.onViewAttachedToWindow(holder)
holder.onAttached()
}
override fun onViewDetachedFromWindow(holder: VH) {
super.onViewDetachedFromWindow(holder)
holder.onDetached()
}
}
然后,扩展MyAdapter
到LifecyclePagedListAdapter<MyEntity, LifecycleViewHolder>(MY_COMPARATOR)
和MyViewHolder
。LifecycleViewHolder(view)
相应地,您必须根据我们所做的更改来完成您的课程。现在我们可以观察到类上的一个liveData
对象MyViewHolder
。所以我们可以将它添加到MyViewHolder
类中(假设您使用的是依赖注入)。基本上,我们会为Fragments
or做同样的事情Activities
:
private lateinit var myViewModel: MyViewModel
init {
(itemView.context as? AppCompatActivity)?.let{
myViewModel = ViewModelProviders.of(it).get(MyViewModel::class.java)
}
}
然后,在bind()
方法内部:
fun bind(myCell: MyEntity?) {
myViewModel.myLiveData.observe(this, Observer {
// Buala!! Check if it is the cell you want to change and update it.
if (it != null && myCell != null && it.id == myCell.id) {
updateCell(it)
}
})
}