element el-form如何避免打开模态框时就进行表单验证

在项目中,经常需要一些校验字段名是否存在的表单验证,比如新增修改用户时需要校验所填写的用户名是否已存在,避免出现重复的用户名。
问题描述
最近遇到一个奇怪的问题,在打开修改模态框未做任何修改时,就自动触发了一次校验,提示用户名已存在或者刚打开新增模态框未进行任何操作,就自动进行了校验,提示各个字段不能为空。

解决办法
通过查看element文档,发现el-form有一个属性
在这里插入图片描述
在这里插入图片描述
设置此属性之后就解决上述问题,希望我的问题记录能帮到你哟!

  • 5
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
可以使用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来创建响应式对象formData和formRules,formData用于存放表单数据,formRules用于存放表单的验证规则。 el-form组件作为表单容器,通过ref="form"指定参考名称,然后通过:model绑定formData数据模型,用:rules绑定表单验证规则。 el-form-item组件作为表单元素的包裹容器,通过label属性指定标签文字,再使用prop属性命名表单元素的key,与表单验证规则对应。 验证规则定义可包括以下属性: - required:表示是否为必填字段 - message:表示验证不通过的提示信息 - trigger:表示触发验证的事件,默认为blur 最后,在提交表单,我们使用validate方法对表单进行验证,需要在回调函数中判断验证结果并作出相应操作。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值