首先来看一下BUG的效果
从上面可以看到当我点击了第一个Item的checkbox的时候,滚到下面的时候有一个也同时被点击了,这是由于holder的服用导致的Bug。
解决方法有两个:
①、直接设置recycleAdapter禁止复用
viewHolder.setIsRecyclable(false);
当然啦,当数据特别多的时候,这个方法是不可行的,这会导致OOM
②、用一个List来记录每个Item的状态
先贴代码
//解决holder复用问题
private List<Integer> favorList=new ArrayList<>();
这里用一个List来保存每个Item的position,来唯一标识这个Item,当然啦,
得先给这个Item打上一个标签,这个是必须的,标识这个Item,以下代码在onBindViewHolder函数里面实现
((DisViewHolder) holder).favor.setTag(new Integer(position));
接着就是先判断,如果当前这个Item的tag是在List里面,那就代表着选中状态,否则就是未选中状态
if(favorList.contains(((DisViewHolder) holder).favor.getTag()))
((DisViewHolder) holder).favor.setChecked(true);
else
((DisViewHolder) holder).favor.setChecked(false);
最后,在favor这个checkbox的setOnCheckedChangeListener监听方法里面如下操作
((DisViewHolder)holder).favor.setOnCheckedChangeListener(new CompoundButton.OnCheckedChangeListener() {
@Override
public void onCheckedChanged(CompoundButton compoundButton, boolean isChecked) {
if (isChecked){
if(!favorList.contains(((DisViewHolder) holder).favor.getTag())){
favorList.add(new Integer(position));
}
}else{
if(favorList.contains(((DisViewHolder) holder).favor.getTag())){
favorList.remove(new Integer(position));
}
}
}
});
很明显,当点击checkbox的时候,在ischecked里面的两个if是判断当前的Item是否已经在List里面了,如果在的话那就remove掉,如果不在就add进来。
接着看一下效果
checkbox选择不再错乱了。
至此,文章结束,希望能帮助到有需要的朋友,谢谢。