vue+elementUI多个表单同时校验

在项目开发中会遇到多个表单块同时做校验的情况,这时候会因为代码分散或者呈现在不同组件而无法一次性校验完成。

父组件调用

let valid = await this.$refs.formData.handleSubmitForm()

子组件

//在data中定义
refArr: ['form1','form2']
//提交或者保存
    handleSubmitForm() {
      const v = new Promise((resolve, reject) => {
        Promise.all(this.refArr.map(this.checkForm)).then(res => {
          const validateResult = res.every(item => !!item)
          if (validateResult) {
            resolve(validateResult)
            console.log(res, '表单都验证成功了')
          } else {
            reject(validateResult)
            console.log(res, '表单未校验通过')
          }
        })
      })
      return v
    },
    checkForm(formName) {
      let t = this
      return new Promise(resolve => {
        t.$refs[formName][0].validate(res => {
          resolve(res)
        })
      })
    },
    //清除表单内容
    handleresetFields() {
      this.refArr.forEach(el => {
        this.resetForm(el)
      })
    },
    resetForm(formName) {
      this.$refs[formName][0].resetFields()
    }

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值