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()
          }
        })
      })
    },
相关推荐
Qrun7 小时前
Windows11安装nvm管理node多版本
前端·vscode·react.js·ajax·npm·html5
中国lanwp7 小时前
全局 npm config 与多环境配置
前端·npm·node.js
JELEE.8 小时前
Django登录注册完整代码(图片、邮箱验证、加密)
前端·javascript·后端·python·django·bootstrap·jquery
TeleostNaCl10 小时前
解决 Chrome 无法访问网页但无痕模式下可以访问该网页 的问题
前端·网络·chrome·windows·经验分享
前端大卫12 小时前
为什么 React 中的 key 不能用索引?
前端
你的人类朋友12 小时前
【Node】手动归还主线程控制权:解决 Node.js 阻塞的一个思路
前端·后端·node.js
小李小李不讲道理14 小时前
「Ant Design 组件库探索」五:Tabs组件
前端·react.js·ant design
毕设十刻14 小时前
基于Vue的学分预警系统98k51(程序 + 源码 + 数据库 + 调试部署 + 开发环境配置),配套论文文档字数达万字以上,文末可获取,系统界面展示置于文末
前端·数据库·vue.js
mapbar_front15 小时前
在职场生存中如何做个不好惹的人
前端
牧杉-惊蛰15 小时前
纯flex布局来写瀑布流
前端·javascript·css