如何取消element 弹窗中form表单的校验信息

场景

当用户在弹窗的表单中输入某些选项触发错误校验信息时,关闭弹窗再次打开,表单仍然存在错误校验信息,这不影响正常的功能使用,但会给用户带来困扰。

解决方案

vue2:对vue2来说,对弹窗添加openDlg事件,在事件回调中获取表单dom,清除表单验证信息即可。

 <el-dialog
    :visible.sync="dlgVisible"
    :title="title"
    width="700px"
    @open="openDlg">
    <el-form ref="secForm">
    </el-form>
  </el-dialog>
  methods: {
    openDlg () {
      this.loadData()
      this.$nextTick(() => {
        this.$refs.secForm.clearValidate() //清除表单校验信        
        //this.$refs.secForm.resetFields() //清除表单所有信息
      })
    },
}

其中 resetFields方法清除表单所有信息,clearValidate方法可接受prop字符串或者多个prop组成的数组,清除表单部分prop的校验结果。使用nextTick是为了在页面挂载完毕后执行回调,确保this.$refs能获取到表单元素。

vue3:vue3同理,通过ref获取表单元素,随后在事件回调中执行clearValidate方法即可。具体代码如下:

 <el-dialog
    :visible.sync="dlgVisible"
    :title="title"
    width="700px"
    @open="openDlg">
    <el-form ref='secForm'>
    </el-form>
  </el-dialog>

<script setup>
import { ref, nextTick } from 'vue';

const secForm = ref();

const openDlg= async () => {
  // 等待 Vue 完成 DOM 更新
  await nextTick();
  // 此时可以安全地访问弹窗内部的 DOM 元素
  secForm.value.validate()
};
</script>

Element form组件的表单校验规则和自定义校验方法如下: ### 基本校验规则 在Element UI中,基本的表单校验规则可以通过在`el-form`的`rules`属性中定义。例如,对于`releaseTime`字段,可定义必填规则: ```javascript rules: { releaseTime: [ { required: true, message: "请输入预发布时间", trigger: "blur" } ] } ``` 这里,`required: true`表示该字段为必填项,`message`是校验不通过时显示的提示信息,`trigger`指定触发校验的事件,如`blur`(失去焦点时触发) [^1]。 ### 自定义校验方法 自定义校验方法通过在`rules`中定义`validator`来实现。示例如下: ```javascript rules: { releaseTime: [ { required: true, message: "请输入预发布时间", trigger: "blur" }, { validator: this.checkReleaseTime, trigger: "blur" } ] } ``` 在上述代码中,`checkReleaseTime`是自定义的校验函数,会在`releaseTime`字段失去焦点时触发校验 [^1]。 ### 自定义校验方法的实现 自定义校验函数需要遵循特定的格式,接收三个参数:`rule`(当前的校验规则)、`value`(当前字段的值)、`callback`(校验结果的回调函数)。示例代码如下: ```javascript methods: { checkReleaseTime(rule, value, callback) { // 自定义校验逻辑 if (value === 'invalidValue') { callback(new Error('输入的值无效')); } else { callback(); } } } ``` 当校验不通过时,调用`callback`并传入一个`Error`对象,包含错误信息校验通过则直接调用`callback()` [^1]。 ### 正则校验 在自定义校验中,可以使用正则表达式进行校验。比如在表单中对某个字段进行正则匹配校验,需要在`data`中定义规则,并且规则名称要和`form`中定义的相同: ```vue <el-form :model="editForm" :rules="editFormRules" ref="editFormRef" label-width="70px"> <!-- 表单内容 --> </el-form> ``` ```javascript data() { return { editForm: { // 表单数据 }, editFormRules: { // 自定义正则校验规则 fieldName: [ { pattern: /^[a-zA-Z]+$/, message: '只能输入字母', trigger: 'blur' } ] } }; } ``` 这里,`pattern`属性指定正则表达式,用于对`fieldName`字段进行校验 [^2]。 ### 结合输入限制的校验 可以结合输入限制和校验规则。例如,对输入进行数字限制,并添加校验: ```vue <el-form :model="editItem" :rules="rules" ref="ruleForm" label-width="100px" class="demo-ruleForm"> <el-form-item label="工艺编码" prop="technologyCode"> <el-input v-model="editItem.technologyCode" oninput="value=value.replace(/[^0-9.]/g,'')" maxlength="2" :min="1" :disabled="disabled"></el-input> </el-form-item> </el-form> ``` 上述代码通过`oninput`事件对输入进行过滤,只允许输入数字和小数点,同时结合`rules`进行校验 [^3]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值