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

来源:互联网 发布:js抢票脚本 编辑:程序博客网 时间:2024/06/08 15:55

在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)    }
这样就不会影响用户体验了








阅读全文
0 0