RecyclerView中使用EditText

网上看到博友在ListView中使用EditText时,点击editText后软键盘弹出后会导致光标失去焦点,这里我在使用RecyclerView的时候并没有发现光标问题,这里先跳过光标问题。

使用EditText是主要问题在于如何获取到EditText的值,以及刷新adapter时,出现editText值错乱
//可能是由于RecyclerView的回收,无法使用getView().getText()来获取EditText的值
//很多博友也是使用了addTextChangedListener(watcher())的方式来获取用户输入的值,并且需要及时的保存数据
       TextWatcher watcher = new TextWatcher() {
                @Override
                public void beforeTextChanged(CharSequence charSequence, int i, int i1, int i2) {
                }

                @Override
                public void onTextChanged(CharSequence charSequence, int i, int i1, int i2) {
                }

                @Override
                public void afterTextChanged(Editable editable) {
                    if (TextUtils.isEmpty(editable.toString())) {
                        bean.setValue("");
                    } else {
                        bean.setValue(editable.toString());
                    }
                }
            };

            ((EditTextItemHolder)holder).et_text.addTextChangedListener(watcher);
上述操作方式其实给自己埋了一个坑,仅仅操作EditText时并没有什么反常,而当我需要调用Adapter的刷新方法时候一个大坑等着我们...

常用的刷新方式有以下两种:

adapter.notifyItemChanged(pos);//仅刷新单个item
adapter.notifyDataSetChanged();//刷新整个adapter  否则选中省信息后,市信息不能回归默认

得益于RecyclerView的优化,相比于ListView增加了单个item刷新操作,所以在项目中当我仅需刷新单个item时并没有异常,textWatcher 工作的很正常

当我使用多级联动时候,由于每一级分处不同的item,所以我不得不调用第二种方式去刷新整个item(虽然我也可以多次调用第一种方式,这里讨论必须全部刷新的情况下),刷新完之后发现zheng'ge整个List<String> 混乱了,数据错乱,而我发现仅仅是使用了EditText的地方出错,并且是在使用了TextWatcher的item,似乎找到了问题的根源...

于是,果断开启debug模式,最终确认确实是TextWatcher的问题,由于调用了notifyDataSetChanged()方法,而导致EditText重绘,并且每次都走了textWatcher的afterTextChanged()方法,于是网上查了资料,最终顺利解决了问题。记录如下:
//完整代码
       if (holder instanceof EditTextItemHolder) {
            //1、为了避免TextWatcher在第2步被调用,提前将他移除。
            if (((EditTextItemHolder) holder).et_text.getTag() instanceof TextWatcher) {
                ((EditTextItemHolder) holder).et_text.removeTextChangedListener((TextWatcher) (((EditTextItemHolder) holder).et_text.getTag()));
            }


            // 第2步:移除TextWatcher之后,设置EditText的Text。
            ((EditTextItemHolder) holder).et_text.setText(bean.getValue());


            TextWatcher watcher = new TextWatcher() {
                @Override
                public void beforeTextChanged(CharSequence charSequence, int i, int i1, int i2) {
                }

                @Override
                public void onTextChanged(CharSequence charSequence, int i, int i1, int i2) {
                }

                @Override
                public void afterTextChanged(Editable editable) {
                    if (TextUtils.isEmpty(editable.toString())) {
                        bean.setValue("");
                    } else {
                        bean.setValue(editable.toString());
                    }
                }
            };
            ((EditTextItemHolder) holder).et_text.addTextChangedListener(watcher);
            ((EditTextItemHolder) holder).et_text.setTag(watcher);
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值