axios的this指向_vue使用axios时this指向哪里

这次给大家带来vue使用axios时this指向哪里,使用vue调用axios时的this注意事项有哪些,下面就是实战案例,一起来看一下。

vue使用axios时this指向哪里

本文主要介绍了关于vue使用axios时this的指向问题,下面话不多说了,来一起看看详细的介绍吧。

1.解决办法

在vue中使用axios做网络请求的时候,会遇到this不指向vue,而为undefined,可以使用箭头函数"=>"来解决。如下:

methods: {

loginAction(formName) {

this.$axios.post('http://127.0.0.1/u/subLogin', {

username: this.username,

password: this.password

})

.then(function(response){

console.log(this); //这里 this = undefined

})

.catch((error)=> {

console.log(error); //箭头函数"=>"使this指向vue

});

});

}

}

2. 原因

ES6中的 箭头函数 "=>" 内部的this是词法作用域,由上下文确定(也就是由外层调用者vue来确定)。

3. 题外话

使用"=>"函数,就可以告别之前的两种写法了:

bind(this)来改变匿名函数的this指向

hack写法 var _this= this; :

loginAction(formName) {

var _this= this;

this.$axios.post("...")

.then(function(response){

console.log(_this); //这里 _this 指向vue

})

});

}

相信看了本文案例你已经掌握了方法,更多精彩请关注php教程其它相关文章!

推荐阅读:

JS怎样将json格式数组下载到excel表格里

怎样操作jackson解析json字符串时首字母的大小写转换

Angular验证功能实现步奏

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值