由于工作項目的需要要對商品購買之后添加評價的功能,于是自己仿淘寶的評價的效果圖作為自己項目中的評價效果圖.但是在開發中遇到了一個大坑,就是在動態添加照片之后,刷新適配器的時候.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