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()
          }
        })
      })
    },
相关推荐
掘金安东尼30 分钟前
中小厂前端候选人简历面试拆解:从 HR 面、技术面到主管面的双赢提问法
前端·面试
天平9 小时前
油猴脚本创建webworker踩坑记录
前端·javascript·typescript
原则猫11 小时前
前端基础大厦
前端
陈随易12 小时前
编程语言级别的Skill市场,AI Agent 的未来形态
前端·后端·程序员
SoaringHeart13 小时前
Flutter进阶:基于 EasyRefresh 的下拉刷新封装 n_easy_refresh_mixin.dart
前端·flutter
IT_陈寒15 小时前
Vite的热更新突然不香了,排查三小时差点砸键盘
前端·人工智能·后端
子兮曰15 小时前
Agency-Agents 深度解析:400+ AI 专家的"梦之队"如何重塑开发工作流
前端·后端·vibecoding
竹林81816 小时前
用 The Graph 查询链上数据实战:从手搓 RPC 到 Subgraph,我的 NFT 项目数据加载快了 10 倍
前端·javascript
妙码生花16 小时前
从 PHP 到 AI + Golang,程序员自救转型手记(十九):点选验证码代码逐行目检
前端·后端·go