RecyclerView布局item中使用EditText,在刷新的时候,造成了数据的错乱

1. 造成的原因:

item的复用,在适配器刷新的时候,EditText中Textwatcher被重复调用的问题,由于调用了notifyDataSetChanged()方法,而导致EditText重绘, 并且每次都走了textWatcher的afterTextChanged()方法.导致EditText中的内容发生了错乱的现象.

2. 解决办法:

方法一:强制停用Recyclerview的复用

holder.setIsRecyclable(false);//防止editText数据错乱

方法二:先删除一遍,可以通过设置tag的方式

        //先移除监听
        if (holder.editText.getTag() instanceof TextWatcher) {
            holder.editText.removeTextChangedListener((TextWatcher) holder.originTv.getTag());
            holder.editText.clearFocus()
        }
        holder.editText.setText("");//移除后设置数据
        TextWatcher watcher = new TextWatcher() {
            @Override
            public void beforeTextChanged(CharSequence s, int start, int count, int after) {

            }

            @Override
            public void onTextChanged(CharSequence s, int start, int before, int count) {

            }

            @Override
            public void afterTextChanged(Editable s) {
                if (holder.editText.hasFocus()) {
                    //写你editText的数据改变逻辑

                }
            }
        };
        //重新添加
        holder.editText.addTextChangedListener(watcher);
        //设置tag
        holder.editText.setTag(watcher);

方法一不推荐使用

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 5
    评论
你可以在RecyclerView的Adapter为每个EditText设置FocusChange监听器,然后在监听器处理焦点变化的逻辑。例如,当EditText失去焦点时,可以调用其clearFocus()方法来让其失去焦点。同时,你需要在RecyclerViewItem布局添加一个可获取焦点的控件,例如一个Button,当用户点击这个Button时,你可以调用RecyclerView的requestFocus()方法来让RecyclerView获取焦点,这样所有的EditText就会失去焦点了。 以下是一个简单的示例代码: ```java public class MyAdapter extends RecyclerView.Adapter<MyAdapter.ViewHolder> { private List<String> mData; public MyAdapter(List<String> data) { mData = data; } @NonNull @Override public ViewHolder onCreateViewHolder(@NonNull ViewGroup parent, int viewType) { View view = LayoutInflater.from(parent.getContext()).inflate(R.layout.item_layout, parent, false); return new ViewHolder(view); } @Override public void onBindViewHolder(@NonNull ViewHolder holder, int position) { holder.mEditText.setText(mData.get(position)); holder.mEditText.setOnFocusChangeListener(new View.OnFocusChangeListener() { @Override public void onFocusChange(View v, boolean hasFocus) { if (!hasFocus) { holder.mEditText.clearFocus(); } } }); holder.mButton.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { holder.itemView.requestFocus(); } }); } @Override public int getItemCount() { return mData.size(); } public static class ViewHolder extends RecyclerView.ViewHolder { public EditText mEditText; public Button mButton; public ViewHolder(@NonNull View itemView) { super(itemView); mEditText = itemView.findViewById(R.id.edit_text); mButton = itemView.findViewById(R.id.button); } } } ``` 在上述代码,我们为每个EditText设置了FocusChange监听器,并在监听器处理了焦点变化的逻辑。同时,在Item布局添加了一个Button,并为其设置了点击事件,当用户点击这个Button时,我们调用RecyclerView的requestFocus()方法来让RecyclerView获取焦点,从而让所有的EditText失去焦点。
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值