Vue回调方法内获取不到当前组件this元素的解决方案

在使用事件订阅$on或者使用axios请求数据时,在回调方法内想刷新数据或者调用其他本组件的方法,发现调用不了,this不能指向当前组件的vue实例,提示TypeError: this.xxx is not a function或者其他。

解决方法:使用=>

  • 示例
//修改前
globalBus.$on("test.order.new",function(data){
	//打印获取的数据
	consolo.log(data);
	//调用本组件的其他方法,例如刷新数据  **失败,this指向错误
	this.update(data);
});
//修改后
globalBus.$on("test.order.new",(data) => {
	//打印获取的数据
	consolo.log(data);
	//调用本组件的其他方法,例如刷新数据  **成功,this指向当前vue实例
	this.update(data);
});

=>和function()匿名函数不同。
function匿名函数this指向运行时实际调用该方法的对象。
=>没有自己的this,这里this在编写时已经确定。优点是不会愁于找当前组件的方法,缺点是箭头函数不能用作构造器,和 new一起用会抛出错误。

借鉴原文

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值