android获取EditText内容,TextWatcher按条件触发

android获取EditText内容,TextWatcher按条件触发

背景:

最近在尝试用原生安卓实现仿element-ui表单校验功能,其中涉及到EditText组件内容的动态校验,初步实现功能后,发现重置按钮逻辑异常:
理想情况下,重置按钮触发后,会将所有内容清空,不会触发校验逻辑,观察当前重置逻辑(此处以活动名称为例):

java 复制代码
	private EditText activityName;
    private void handleResetEvent() {
    	// 点击重置按钮
        resetBtn.setOnClickListener(v -> {
            activityName.setText(null);
        });
    }
    private void setActivityNameEvent() {
   		// 活动名称添加内容改变后监听 触发校验活动名称
        activityName.addTextChangedListener(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) {
                verifyActivityName();
            }
        });
    }
	private void verifyActivityName() {
		if (StringUtils.isEmpty(activityNameValue)) {
            activityNameTip.setText("请输入活动名称");
            createVerifyPass = false;
        } else {
            if ((activityNameValue.length() < 3 || activityNameValue.length() > 5)) {
                activityNameTip.setText("长度在3到5个字符");
                createVerifyPass = false;
            } else {
                activityNameTip.setText(null);
            }
        }
	}

debug调试发现走activityName.setText(null);就会马上触发afterTextChanged,进而调用verifyActivityName(),是同步的方法调用,咱们的需求需要在手动修改EditText组件时能够触发校验,而点击重置按钮时EditText组件内容置空不触发校验。

解决方案:

考虑新增一个标识resetBtnClickFlag用来识别当前的动作是否为重置,如果为重置则不触发具体的提示校验:

java 复制代码
	private EditText activityName;
	private boolean resetBtnClickFlag = false;
    private void handleResetEvent() {
    	// 在重置按钮逻辑开始和结束分别设置重置标识开启和关闭
        resetBtn.setOnClickListener(v -> {
            resetBtnClickFlag = true;
            activityName.setText(null);
            selectArea = null;
            selectDate = null;
            selectTime = null;
            timelyDelivery.setChecked(false);
            onlineActivity.setChecked(false);
            pushActivity.setChecked(false);
            offlineActivity.setChecked(false);
            brandExposure.setChecked(false);
            onlineBrandSponsorship.setChecked(false);
            offlineFree.setChecked(false);
            eventFormat.setText(null);
            resetBtnClickFlag = false;
        });
    }
    // 在控制提示信息的具体方法补充重置标识逻辑
    private void verifyActivityName() {
        Editable activityNameValue = activityName.getText();
        if (!resetBtnClickFlag && StringUtils.isEmpty(activityNameValue)) {
            activityNameTip.setText("请输入活动名称");
            createVerifyPass = false;
        } else {
            if (!resetBtnClickFlag && (activityNameValue.length() < 3 || activityNameValue.length() > 5)) {
                activityNameTip.setText("长度在3到5个字符");
                createVerifyPass = false;
            } else {
                activityNameTip.setText(null);
            }
        }
    }

效果:

相关推荐
计蒙不吃鱼4 小时前
一篇文章实现Android图片拼接并保存至相册
android·java·前端
LucianaiB5 小时前
如何做好一份优秀的技术文档:专业指南与最佳实践
android·java·数据库
duwei_wang10 小时前
[Android]-Admob配置过多导致的慢消息
android
雨白11 小时前
发送自定义广播
android
雨白11 小时前
深入理解广播机制 (BroadcastReceiver)
android
婵鸣空啼15 小时前
GD图像处理与SESSiON
android
sunly_16 小时前
Flutter:导航固定背景图,滚动时导航颜色渐变
android·javascript·flutter
用户20187928316717 小时前
简单了解android.permission.MEDIA_CONTENT_CONTROL权限
android
_一条咸鱼_17 小时前
Android Runtime类卸载条件与资源回收策略(29)
android·面试·android jetpack
顾林海17 小时前
Android Bitmap治理全解析:从加载优化到泄漏防控的全生命周期管理
android·面试·性能优化