由于工作项目的需要要对商品购买之后添加评价的功能,于是自己仿淘宝的评价的效果图作为自己项目中的评价效果图.但是在开发中遇到了一个大坑,就是在动态添加照片之后,刷新适配器的时候.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