您的位置:首页 > 其它

Recyclerview item中有EditText使用刷新遇到的坑!!!!!

2017-06-16 10:21 441 查看
由于工作项目的需要要对商品购买之后添加评价的功能,于是自己仿淘宝的评价的效果图作为自己项目中的评价效果图.但是在开发中遇到了一个大坑,就是在动态添加照片之后,刷新适配器的时候.item中的EditText中的文字发生了错乱的现象.最后bug发现由于如下代码产生的原因.

/**
* 这是一个EditText的文本监听,因为在activity中要获取文本内容,所以设置了这个监听.
* 于是,果断开启debug模式,最终确认确实是TextWatcher的问题,由于调用了notifyDataSetChanged()方法,而导致EditText重绘,
* 并且每次都走了textWatcher的afterTextChanged()方法.导致EditText中的内容发生了错乱的现象.
*
*/
TextWatcherListener watcher = new TextWatcherListener() {
@Override
public void afterTextChanged(Editable s) {
holder.mEvaluateNumberTv.setText(s.length() + "/100");
if (mOnClickViewListener != null) {
mOnClickViewListener.showEditTextListener(position, s.toString());
}
}
};

holder.mEtEvaluate.setText(mEvaluateProductMap.get(position).getBuyerEvaluate());
holder.mEtEvaluate.addTextChangedListener(watcher);


最后在网上找了很久才知道是Recyclerview条目复用的时候导致监听事件的重绘,所以只需要去掉Recyclerview的复用就可以完美的解决这个问题饿.但是我们又知道Recyclerview是自带复用的怎么去除复用呢? 只需要在onBindViewHolder(EvaluateHolder holder, int position)中添加如下的的代码就可强制的停用Recyclerview的复用,两种解决方案

第一种就是强制的停用Recyclerview的复用:

holder.setIsRecyclable(false);


第二种通过view的setTag()方法解决Recyclerview的复用代码如下:

holder.mEtEvaluate.setTag(position);//绑定tag标记
holder.mEtEvaluate.clearFocus();
TextWatcherListener watcher = new TextWatcherListener() {
@Override
public void afterTextChanged(Editable s) {
holder.mEvaluateNumberTv.setText(s.length() + "/100");
if (mOnClickViewListener != null) {
mOnClickViewListener.showEditTextListener((int )(holder.mEtEvaluate.getTag()), s.toString()); //通过tag存储

}
}
};
holder.mEtEvaluate.addTextChangedListener(watcher);
holder.mEtEvaluate.setText(mEvaluateProductMap.get((holder.mEtEvaluate.getTag())).getBuyerEvaluate()); //通过控件的tag标记获取值,设置到控件上


这两种方法都能解决问题,只是方法一只适合条目较少的情况,如果你的条目较多就不太适用了希望我踩的坑能给你有所帮助,大家一起进步谢谢!!!!
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  仿淘宝评价
相关文章推荐