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()
          }
        })
      })
    },
相关推荐
灵感__idea2 小时前
Hello 算法:贪心的世界
前端·javascript·算法
GreenTea4 小时前
一文搞懂Harness Engineering与Meta-Harness
前端·人工智能·后端
killerbasd5 小时前
牧苏苏传 我不装了 4/7
前端·javascript·vue.js
吴声子夜歌6 小时前
ES6——二进制数组详解
前端·ecmascript·es6
码事漫谈6 小时前
手把手带你部署本地模型,让你Token自由(小白专属)
前端·后端
ZC跨境爬虫6 小时前
【爬虫实战对比】Requests vs Scrapy 笔趣阁小说爬虫,从单线程到高效并发的全方位升级
前端·爬虫·scrapy·html
爱上好庆祝6 小时前
svg图片
前端·css·学习·html·css3
王夏奇6 小时前
python中的__all__ 具体用法
java·前端·python
大家的林语冰7 小时前
《前端周刊》尤大开源 Vite+ 全家桶,前端工业革命启动;尤大爆料 Void 云服务新产品,Vite 进军全栈开发;ECMA 源码映射规范......
前端·javascript·vue.js
jiayong237 小时前
第 8 课:开始引入组合式函数
前端·javascript·学习