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

时间:2019-04-14
本文章向大家介绍详解Recyclerview item中有EditText使用刷新遇到的坑,主要包括详解Recyclerview item中有EditText使用刷新遇到的坑使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。

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

这两种方法都能解决问题,只是方法一只适合条目较少的情况,如果你的条目较多就不太适用了希望我踩的坑能给你有所帮助,大家一起进步谢谢!!!!

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。