解决RecyclerView里有多个EditText输入框导致数据错乱

1.初始图
这里为刚开始
在滑动后就变成了这样
在这里插入图片描述
解决方法如下

 if (znTime.getTag() != null) {
            znTime.removeTextChangedListener((TextWatcher) znTime.getTag());
        }
        TextWatcher textWatcher = 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(s.length() > 0) {
                    getData().get(helper.getAdapterPosition()).setDt_daytime(s.toString());
                }
            }
        };
        znTime.addTextChangedListener(textWatcher);
        znTime.setTag(textWatcher);
        znTime.setText( item.getDt_daytime());

上边为一个列表为edittext多个其实也一样(有几个就按照这个方法写几个就可以把znTime换成其他的输入框名即可)只不过如果每次都是重复写的话就增加代码了(能少写为什么要多写呢)

//这个调用的方法放入到适配器中
returnData(helper,znTime,item,0);
 /**
     * 解决输入框重复问题
     * @param helper BaseViewHolder
     * @param editText 输入框
     * @param item 实体类
     * @param i 这个为自己定义的为了后边的switch语句
     */
    private void returnData(BaseViewHolder helper,EditText editText,TrainingDayAchievesAssessCculum item,int i){
        if (editText.getTag() != null) {
            editText.removeTextChangedListener((TextWatcher) editText.getTag());
        }
        TextWatcher textWatcher2 = 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(s.length() > 0) {
                    switch (i){
                        case 0:
                            getData().get(helper.getAdapterPosition()).setDt_daytime(s.toString().trim());
                            break;
                        case 1:
                            getData().get(helper.getAdapterPosition()).setDt_night(s.toString().trim());
                            break;
                        case 2:
                            getData().get(helper.getAdapterPosition()).setCdt_daytime(s.toString().trim());
                            break;
                        case 3:
                            getData().get(helper.getAdapterPosition()).setCdt_night(s.toString().trim());
                            break;
                        case 4:
//                            item.set(s.toString().trim());
//                            getData().get(helper.getAdapterPosition()).setCdt_daytime(s.toString().trim());
                            break;
                        case 5:
                            getData().get(helper.getAdapterPosition()).setRemarks(s.toString().trim());
                            break;
                        default:
                            break;
                    }
                }
            }
        };
        editText.addTextChangedListener(textWatcher2);
        editText.setTag(textWatcher2);
        switch (i){
            case 0:
                editText.setText(item.getDt_daytime());
                break;
            case 1:
                editText.setText(item.getDt_night());
                break;
            case 2:
                editText.setText(item.getCdt_daytime());
                break;
            case 3:
                editText.setText(item.getCdt_night());
                break;
            case 4:
//                editText.setText(item.getDt_daytime());
                break;
            case 5:
                editText.setText(item.getRemarks());
                break;
            default:
                break;
        }
    }
        

经过上边的代码修改后就可以了如下图
滑动后没有回到原来的位置
重新滑动到刚开始的位置
第一个图为滑动后但是没有重新滑动到原来的位置,第二个为重新回到原来位置图;
电脑上没有截动图的软件所以只能截个静图了,最终效果自己可以去试下;

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
你可以在RecyclerView的Adapter中为每个EditText设置FocusChange监听器,然后在监听器中处理焦点变化的逻辑。例如,当EditText失去焦点时,可以调用其clearFocus()方法来让其失去焦点。同时,你需要在RecyclerView的Item布局中添加一个可获取焦点的控件,例如一个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失去焦点。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值