vue之$emit 获取返回值

使用场景:子组件调用父组件的方法并获取到父组件方法的返回值

1.子组件方法:

获取父组件的值,判断是否关闭弹框

handleConfirm() {
      this.$refs.form.validate((valid) => {
        if (!valid) {
          return false;
        }

        const data = Object.assign({}, this.form);

        var success = false;
        this.$emit('change', data, val => {
          success = val
        });
        // 成功
        if (success) {
          this.showDialog = false;
        }
      });
    },

2、父组件方法

第2个参数callback:函数,传值,false代表校验失败,不执行之后逻辑。

callback(false);

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

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

      this.variableList = data;

      // 回调数据,保存
      callback(true);
    },

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值