由于工作项目的需要要对商品购买之后添加评价的功能,于是自己仿淘宝的评价的效果图作为自己项目中的评价效果图.但是在开发中遇到了一个大坑,就是在动态添加照片之后,刷新适配器的时候.item中的EditText中的文字发生了错乱的现象.最后bug发现由于如下代码产生的原因.
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
|
/**
* 这是一个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的复用:
1
|
holder.setIsRecyclable( false );
|
第二种通过view的setTag()方法解决Recyclerview的复用代码如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
|
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标记获取值,设置到控件上
|
这两种方法都能解决问题,只是方法一只适合条目较少的情况,如果你的条目较多就不太适用了希望我踩的坑能给你有所帮助,大家一起进步谢谢!!!!
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持服务器之家。
原文链接:https://blog.csdn.net/wmz199123/article/details/73321990?t=1498445624899