实现vue3 element-plus form组件 validate 同步校验返回

其实比较简单,因为 validate方法 返回的是 Promise,所以利用async await 就可以实现啦。

子组件

抛出submit 方法

校验失败时,await this.$refs.form.validate(); 直接抛出异常,程序不往下走;

校验成功时,继续执行下面的代码

    async submit() {
      // 验证表单
      // 校验失败时,直接抛出异常,程序不往下走;
      // 校验成功时,继续执行下面的代码
      await this.$refs.form.validate();

      const data = Object.assign({}, this.form);
      data.variableType = this.form.variableType;
      if (this.form.variableType == 'other') {
        data.variableType = this.variableTypeInput;
      }

      return data;
    }
父组件

调用子组件方法,并获取返回值


    // 修改变量框提交
    async changeVariable(){
      const result = await this.$refs.variableDialog.submit();
      if (result) {
        var temp = {};
        Object.assign(temp, result);

        var data = JSON.parse(JSON.stringify(this.variableList));
        if (this.variableIndex == -1) {
          data.push(temp);
        } else {
          data[this.variableIndex] = temp;
        }

        //校验表格数据
        if (!this.checkData(data)) {
          this.$message.error('变量名称重复!');
          return false;
        }

        this.variableList = data;

        // 关闭窗口
        this.$refs.variableDialog.showDialog = false;
      }

    },

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值