关于Vue中抽取公共方法涉及this指向问题

今天做项目的时候,多个页面用到同一个方法,所以呢就想能够将这个方法抽取出来,能够减少代码的复用。
可是我遇到了一个问题,就是里面涉及了this的指向,我是用到了路由跳转,所以就有以下的这种报错警告:

在这里插入图片描述
[Vue warn]: Error in v-on handler: “TypeError: Cannot read property ‘$router’ of undefined”

抽取的公共方法common.js里面的部分代码:

在这里插入图片描述

我想了一下,也没有明白,大概猜出来应该是this的问题,可是不懂怎么解决,就只能问了。

得到的回复是,我这样要用的this是使用这个方法的时候的this指向才对,所以要从调用的这个方法的时候,将this传过来,这样就可以解决。

我在调用方法的页面是这样的:

在这里插入图片描述
我们需要将this传过去,也就是如下图修改:

在这里插入图片描述
然后在公共方法common.js进行接收就可以了:

在这里插入图片描述
这样就可以了~

就这样,记录一下自己遇到的问题。

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值