温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

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

发布时间:2020-09-23 23:31:27 来源:脚本之家 阅读:324 作者:ITKobi小丸子 栏目:移动开发

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

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

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

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI