el-form多表单校验

思路:使用Promise.all以及elementui自带的表单校验去判断

html 复制代码
<el-form ref="form" :model="formData">
    ....
</el-form>

<el-form ref="formTwo"  :model="formDataTwo">
    ....
</el-form>

<el-form ref="formThird"  :model="formDataThird">
    ....
</el-form>
...

      <span slot="footer" class="dialog-footer">
        <el-button @click="handleClickCancel">{{ '取消' }}</el-button>
        <el-button type="primary" @click="validFormHandle">{{ '确定' }}</el-button>
      </span>

需求:所有表单通过校验后才可以请求接口

javascript 复制代码
    /**
     * @description: 确定的点击事件
     * @return {*}
     */
    validFormHandle() {
      Promise.all(['formData', 'formDataTwo','formDataThird'].map(item => this.validForm(item))).then(() => {
        this.handleClickOk()
      }).catch(error => {
        this.$message({
          showClose: true,
          message: '请先检查表单是否都已填写',
          type: 'warning'
        })
        console.log('error', error)
      })
    },
    handleClickOk() {
      const params = { ...this.formData, ...this.formDataTwo,...this.formDataThird }
//请求接口处理
xxx(params).then(res =>{
    this.$message.success(res.msg)
)
    },
    // 校验表单
    validForm(formRef) {
      return new Promise((resovle, reject) => {
        this.$refs[formRef].validate(valid => {
          if (valid) {
            resovle()
          } else {
            reject()
          }
        })
      })
    },
相关推荐
We་ct13 小时前
AI辅助开发术语体系深度剖析
开发语言·前端·人工智能·ai·ai编程
去伪存真13 小时前
Superpowers 从“调教提示词”转向“构建工程规范”
前端·agent
发现一只大呆瓜13 小时前
深度起底 Vite:从打包流程到插件钩子执行时序的全链路解析
前端·vite
jserTang13 小时前
Claude Code 源码深度解析 - 前言
前端·javascript·后端
hehelm13 小时前
vector模拟实现
前端·javascript·算法
|晴 天|13 小时前
[特殊字符]️ Vue 3项目架构设计:从2200行单文件到24个组件
前端·javascript·vue.js
Ruihong13 小时前
Vue v-html 与 v-text 转 React:VuReact 怎么处理?
vue.js·react.js·面试
Fisschl13 小时前
Vue 封装 Echarts 组件
vue.js
FrontAI13 小时前
深入浅出 LangChain —— 第三章:模型抽象层
前端·人工智能·typescript·langchain·ai agent
givemeacar14 小时前
spring-boot-starter和spring-boot-starter-web的关联
前端