12

使用新的分页库时,更新单个元素的最佳方式是什么?

假设我们有Paging with network google 示例,使用PageKeyedSubredditDataSource. 想象一下,我们想要更改RedditPost. 因此,我们要检查它是否在列表中,如果是,则更新它。更新不应该像调用 invalidate() 那样简单,它将调用第一页(可能 RedditPost 在第 5 页。我们不想更新所有元素,只更新一个)。

4

1 回答 1

2

请注意,所有这些都适用于Paging with network google 示例。尽管如此,这个想法是存在的。

@Sarquella 帮助我解决了这个问题。将此类添加到您的项目中。基本上我们正在扩展ViewHolder为 be LifeCycle Owner,因为默认情况下已经使用Activitiesand完成了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()
    }
}

然后,扩展MyAdapterLifecyclePagedListAdapter<MyEntity, LifecycleViewHolder>(MY_COMPARATOR)MyViewHolderLifecycleViewHolder(view)相应地,您必须根据我们所做的更改来完成您的课程。现在我们可以观察到类上的一个liveData对象MyViewHolder。所以我们可以将它添加到MyViewHolder类中(假设您使用的是依赖注入)。基本上,我们会为Fragmentsor做同样的事情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)
        }
    })
}
于 2018-09-27T06:11:41.267 回答