vue-使用el-form表单时blur事件和button的点击事件冲突的解决方案

前言

最近在项目中遇到一个场景,就是在校验输入框失焦(blur)事件后,第一次点击时按钮的点击事件失效,后来排查,发现原因,是因为第一次点击时先走了blur事件,然后再走点击事件,所以导致第一次点击按钮失效。

出现bug的原因

由于浏览器的默认事件,当你点击按钮时,页面中有文本框失焦时,会先触发文本框的blur事件,然后再触发click事件,所以导致了上述的bug。解决方案如下。

解决方案

pc端:使用mousedown事件来代替click事件
移动端:使用touchstart事件来代替click事件

可以使用Vue3中内置的v-model以及element-plus中提供的el-formel-form-item组件,设置相应的验证规则提示信息即可。 示例代码如下: ```html <template> <el-form ref="form" :model="formData" :rules="formRules"> <el-form-item label="用户名" prop="username"> <el-input v-model="formData.username"></el-input> </el-form-item> <el-form-item label="密码" prop="password"> <el-input v-model="formData.password" type="password"></el-input> </el-form-item> <el-form-item> <el-button type="primary" @click="submitForm">提交</el-button> </el-form-item> </el-form> </template> <script> import { ref } from 'vue'; import { ElMessage } from 'element-plus'; export default { name: 'FormValidation', setup() { const formData = ref({ username: '', password: '', }); const formRules = ref({ username: [{ required: true, message: '请输入用户名', trigger: 'blur', }], password: [{ required: true, message: '请输入密码', trigger: 'blur', }], }); const submitForm = () => { // 提交表单操作 const form = ref('form'); form.value.validate((valid) => { if (valid) { // 验证通过执行提交操作 ElMessage.success('提交成功'); } else { ElMessage.warning('请填写完整信息'); return false; } }); }; return { formData, formRules, submitForm, }; }, }; </script> ``` 在这个示例中,我们使用了ref来创建响应式对象formDataformRules,formData用于存放表单数据,formRules用于存放表单的验证规则。 el-form组件作为表单容器,通过ref="form"指定参考名称,然后通过:model绑定formData数据模型,用:rules绑定表单验证规则。 el-form-item组件作为表单元素的包裹容器,通过label属性指定标签文字,再使用prop属性命名表单元素的key,表单验证规则对应。 验证规则定义可包括以下属性: - required:表示是否为必填字段 - message:表示验证不通过的提示信息 - trigger:表示触发验证的事件,默认为blur 最后,在提交表单,我们使用validate方法对表单进行验证,需要在回调函数中判断验证结果并作出相应操作。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值