Vue中使用 Element-ui form和 el-dialog 进行自定义表单校验&清除表单状态

文章目录

问题

在使用 Element-ui el-formel-dialog 进行自定义表单校验时,出现点击编辑按钮之后再带年纪新增按钮,出现如下情况,新增弹出表单进行了一次表单验证,而这时不应该要表单验证的

分析

在寻找多种解决方案后,最后用的方法时在打开弹窗第一次取消校验规则,这里我使用的是el-dialog的@open和@close来处理

需要注意的是要在清除方法外面用$nextTick处理一下在DOM渲染完成后在操作

不然会有问题,如果不需要清除的话可以不调用回调方法

javascript 复制代码
 //弹框打开的时
    getOpen() {
      // 移除校验状态
      // this.$refs.form.resetField()
      this.$nextTick(() => {
        this.$refs.form.clearValidate()

      })
    },
    //关闭弹窗
    close() {
      this.$nextTick(() => {
        this.$refs.form.resetFields()
      })
    }
  • 全部代码
js 复制代码
<template>
  <div>
    <el-button @click="dialogFormVisible=true">新增</el-button>
    <el-dialog @open="getOpen" @close="close" title="测试新增" :close-on-click-modal="false" :visible.sync="dialogFormVisible" width="40%" append-to-body>
      <el-form ref="form" :model="form" :rules="rules">
        <el-form-item label="姓名" :label-width="formLabelWidth" prop="name">
          <el-input v-model="form.name" autocomplete="off"></el-input>
        </el-form-item>
        <el-form-item :label-width="formLabelWidth" prop="region">
          <label slot="label"><i style="color:red;">*&nbsp; </i> 性别</label>
          <el-select v-model="form.region" placeholder="请选择性别">
            <el-option label="男" value="1"></el-option>
            <el-option label="女" value="2"></el-option>
          </el-select>
        </el-form-item>
      </el-form>
      <div slot="footer" class="dialog-footer">
        <el-button @click="dialogFormVisible = false">取 消</el-button>
        <el-button type="primary" @click="Add">确 定</el-button>
      </div>
    </el-dialog>
  </div>
</template>
<script>
export default {
  data() {
    return {
      formLabelWidth: '120px',
      dialogFormVisible: false,
      form: {
        name: '',
        region: ''
      },
      rules: {
        name: [
          {
            required: true,
            pattern: /^[a-zA-Z0-9]+$/,
            message: '只能输入数字或大小写字母',
            trigger: 'blur'
          }
        ],
        region: [{ validator: this.validatorRegion, trigger: 'change' }]
      }
    }
  },
  methods: {
    //自定义校验方法
    validatorRegion(rule, value, callback) {
      if (!this.form.region) {
        callback(new Error('请选择性别'))
      } else {
        callback()
      }
    },
    Add() {
      this.$refs.form.validate((valid) => {
        console.log(valid)
        if (valid) {
          this.$message.success('校验成功')
          this.dialogFormVisible = !this.dialogFormVisible
        } else {
          this.$message.warning('校验失败')
        }
      })

    },
    //弹框打开的时
    getOpen() {
      // 移除校验状态
      this.$nextTick(() => {
        this.$refs.form.clearValidate()

      })
    },
    //关闭弹窗
    close() {
    //清除用户输入
      this.$nextTick(() => {
        this.$refs.form.resetFields()
      })
    }
  }
}
</script>
<style lang="less" scoped>
</style>
相关推荐
东东5161 小时前
智能社区管理系统的设计与实现ssm+vue
前端·javascript·vue.js·毕业设计·毕设
catino1 小时前
图片、文件的预览
前端·javascript
2501_920931702 小时前
React Native鸿蒙跨平台实现推箱子游戏,完成玩家移动与箱子推动,当所有箱子都被推到目标位置时,玩家获胜
javascript·react native·react.js·游戏·ecmascript·harmonyos
AI老李3 小时前
PostCSS完全指南:功能/配置/插件/SourceMap/AST/插件开发/自定义语法
前端·javascript·postcss
方也_arkling3 小时前
Element Plus主题色定制
javascript·sass
晓晓莺歌3 小时前
vue3某一个路由切换,导致所有路由页面均变成空白页
前端·vue.js
2601_949809593 小时前
flutter_for_openharmony家庭相册app实战+我的Tab实现
java·javascript·flutter
Up九五小庞4 小时前
开源埋点分析平台 ClkLog 本地部署 + Web JS 埋点测试实战--九五小庞
前端·javascript·开源
摘星编程4 小时前
React Native + OpenHarmony:UniversalLink通用链接
javascript·react native·react.js
qq_177767374 小时前
React Native鸿蒙跨平台数据使用监控应用技术,通过setInterval每5秒更新一次数据使用情况和套餐使用情况,模拟了真实应用中的数据监控场景
开发语言·前端·javascript·react native·react.js·ecmascript·harmonyos