vue之$emit返回值

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

方法(一): 回调函数:

1.子组件方法:

……
 
methods:{
        ShowMore(step){
                this.$emit("ChildClick",step,(res)=>{
                          //回调函数的方法体.处理自己的业务.
                 });
 
        }
 
}
 
……

2、父组件方法

……
 
methods:{
 
        ShowMore(step,callback){
 
                let  result = step++;//这里只做一个demo,这里是父级方法体执行完成后,返回一个值.
 
                callback(result);//这是关键,调用子组件中的回调方法.
 
        }
 
}
 
……

如果是兄弟组件的话采用事件车

// 定义全局事件车
Vue.prototype.$bus= new Vue();
……
created() {
this.$bus.$on('ShowMore', (step,callback) => {
         let  result = step++;//这里只做一个demo,这里是父级方法体执行完成后,返回一个值.
 
          callback(result);//这是关键,调用子组件中的回调方法.
       
      }
    );
}
 
……

方法(二):采用Promise

1、子组件方法

……
 
methods:{
 
        ShowMore(step){
 
               let res = await  this.$emit("ChildClick",step);
 
                //拿到res后,如果还有其他逻辑,继续处理返回值 res; 下略.               
 
        }
 
}
 
……

2、父组件方法

……
 
methods:{
 
        ShowMore(step,callback){
 
                return new Promise((resolve)=>{
 
                           let res = step++;
 
                           resolve(res);
                });
 
        }
 
}
 
……

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值