RecyclerView.Adapter关于notifyItemInserted等数据错位问题

在RecyclerView.Adapter中,平时我们刷新的方法是:

notifyDataSetChanged()


其实 ,RecyclerView.Adapter中为我们提供了很多自带酷炫的增加删除动画,包括局部刷新的方法。


·notifyItemInserted(int position): 列表position位置添加一条数据时可以调用,伴有动画效果

·notifyItemRemoved(int position) :列表position位置移除一条数据时调用,伴有动画效果

·notifyItemMoved(int fromPosition, int toPosition) 列表fromPosition位置的数据移到toPosition位置时调用,伴有动画效果

·notifyItemRangeChanged(int positionStart, int itemCount) 列表从positionStart位置到itemCount数量的列表项进行数据刷新

·notifyItemRangeInserted(int positionStart, int itemCount) 列表从positionStart位置到itemCount数量的列表项批量添加数据时调用,伴有动画效果

·notifyItemRangeRemoved(int positionStart, int itemCount) 列表从positionStart位置到itemCount数量的列表项批量删除数据时调用,伴有动画效果

需要注意的地方,在使用这些方法的时候,google官方文档中提到他们的position会自动增加,但是在实际操作过程中,并没有增加,导致数据错位的问题,所以,当我们需要使用这些特效方法的时候,必须要重新刷新一遍数据,纠正position。

 //两个item之间互换位置
    fun changeItem(fromPosition: Int, endPosition: Int) {
        Collections.swap(mList, fromPosition, endPosition)
        notifyItemMoved(fromPosition, endPosition)
        // 加入如下代码保证position的位置正确性
        notifyItemRangeChanged(0, mList.size)
    }

这里的notifyItemRangeChanged(0, mList.size)是最懒的方法,把所有的ui都刷新了一遍,你也可以通过notifyItemRangeChanged(int positionStart, int itemCount) 这个方法,刷新局部,来优化性能。

还有一个问题就是当你操作的是第一个item的时候,比如插入完成的时候,第一个不会自动出现在recycleView的顶部,这个时候你需要自己手动将recycleView滑动到顶部。

 override fun scrollToTop() {
        recycleView.scrollToPosition(0)
    }
这样就不会影响用户体验了








  • 5
    点赞
  • 23
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值