浅谈vue使用axios的回调函数中this不指向vue实例,为undefined


Posted in Javascript onSeptember 21, 2020

今天在vue-cli脚手架搭建的项目中使用axios时,遇到无法解析this.$route的报错信息,最后发现是作用域的问题。

1.解决方法:使用 =>

原代码:

axios.get('/user', {
  params: {
   ID: 12345
  }
 })
 .then(function (response) {
  console.log(response);
 })
 .catch(function (error) {
  console.log(error);
 });

修改为:

axios.get('/user', {
  params: {
   ID: 12345
  }
 })
 .then((response) => {
  console.log(response);
 })
 .catch((error) => {
  console.log(error);
 });

2.=>解析

在JS中,箭头函数并不是简单的function(){}匿名函数的简写语法糖,实际上,箭头函数和匿名函数有个明显的区别:箭头函数内部的this是词法作用域,在编写函数时就已经确定了,由上下文确定。而匿名函数的this指向运行时实际调用该方法的对象,无法在编写函数时确定。

不可以当做构造函数,也就是说,不可以使用 new 命令,否则会抛出错误。

this、arguments、caller等对象在函数体内都不存在。

不可以使用 yield 命令,因此箭头函数不能用作 Generator 函数。

箭头函数除了传入的参数之外,其它的对象都没有!在箭头函数引用了this、arguments或者参数之外的变量,那它们一定不是箭头函数本身包含的,而是从父级作用域继承的。

补充知识:axios 中请求的回调函数中的this指针问题

请看下面两组代码

this.axios.post(url, data)
.then(function(result) {
var resData = result.data
console.log(resData)
if (resData.status === 1) {
} else {
}
})
.catch(function (error) {
console.log(error)
})

this.axios.post(url, data)
.then((result) => {
var resData = result.data
console.log(resData)
if (resData.status === 1) {
} else {
}
})
.catch(function (error) {
console.log(error)
})

这两组代码的差别在于:请求成功后的回调函数,一个使用匿名函数,一个使用箭头函数

匿名函数的指针指向->函数操作的本身

箭头函数的指针指向->组件

也就是说当你需要使用到组件中声明的变量或者函数,就需要使用箭头函数

以上这篇浅谈vue使用axios的回调函数中this不指向vue实例,为undefined就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
两个select之间option的互相添加操作(jquery实现)
Nov 12 Javascript
javascript:json数据的页面绑定示例代码
Jan 26 Javascript
jscript读写二进制文件的方法
Apr 22 Javascript
Javascript中的getUTCDay()方法使用详解
Jun 10 Javascript
JavaScript中字符串(string)转json的2种方法
Jun 25 Javascript
跟我学习javascript的undefined与null
Nov 17 Javascript
第九篇Bootstrap导航菜单创建步骤详解
Jun 21 Javascript
JavaScript实现类似拉勾网的鼠标移入移出效果
Oct 27 Javascript
详解基于vue-cli3.0如何构建功能完善的前端架子
Oct 09 Javascript
JQuery属性操作与循环用法示例
May 15 jQuery
layui(1.0.9)文件上传upload,前后端的实例代码
Sep 26 Javascript
如何使用three.js 制作一个三维的推箱子游戏
Jul 29 Javascript
vue大型项目之分模块运行/打包的实现
Sep 21 #Javascript
Vue+Element ui 根据后台返回数据设置动态表头操作
Sep 21 #Javascript
JS实现小米轮播图
Sep 21 #Javascript
vue 里面的 $forceUpdate() 强制实例重新渲染操作
Sep 21 #Javascript
vue组件入门知识全梳理
Sep 21 #Javascript
Ajax获取node服务器数据的完整步骤
Sep 20 #Javascript
微信小程序获取当前时间及星期几的实例代码
Sep 20 #Javascript
You might like
简单实用的网站PHP缓存类实例
2014/07/18 PHP
thinkPHP+PHPExcel实现读取文件日期的方法(含时分秒)
2016/07/07 PHP
php简单实现多维数组排序的方法
2016/09/30 PHP
Prototype使用指南之form.js
2007/01/10 Javascript
一组JS创建和操作表格的函数集合
2009/05/07 Javascript
Javascript 面向对象特性
2009/12/28 Javascript
javascript + jquery实现定时修改文章标题
2014/03/19 Javascript
javascript操作excel生成报表全攻略
2014/05/04 Javascript
Jquery $.getJSON 在IE下的缓存问题解决方法
2014/10/10 Javascript
JS提交form表单实例分析
2015/12/10 Javascript
JavaScript如何实现对数字保留两位小数一位自动补零
2015/12/18 Javascript
AngularJS使用ngOption实现下拉列表的实例代码
2016/01/23 Javascript
Javascript生成带参数的二维码示例
2016/10/10 Javascript
Bootstrap实现导航栏的2种方式
2016/11/28 Javascript
Three.js获取鼠标点击的三维坐标示例代码
2017/03/24 Javascript
在Vue组件上动态添加和删除属性方法
2018/02/23 Javascript
解决vue 使用setTimeout,离开当前路由setTimeout未销毁的问题
2020/07/21 Javascript
VUE动态生成word的实现
2020/07/26 Javascript
python使用urlparse分析网址中域名的方法
2015/04/15 Python
在Python中处理日期和时间的基本知识点整理汇总
2015/05/22 Python
Python中random模块生成随机数详解
2016/03/10 Python
python绘制圆柱体的方法
2018/07/02 Python
python GUI库图形界面开发之PyQt5动态(可拖动控件大小)布局控件QSplitter详细使用方法与实例
2020/03/06 Python
Jupyter notebook如何修改平台字体
2020/05/13 Python
Python脚本打包成可执行文件过程解析
2020/10/20 Python
python自动从arxiv下载paper的示例代码
2020/12/05 Python
CSS3动画特效在活动页中的应用
2020/01/21 HTML / CSS
佳能加拿大网上商店:Canon eStore Canada
2018/04/04 全球购物
草莓网官网:StrawberryNET
2019/08/21 全球购物
技术总监管理职责范本
2014/03/06 职场文书
喷漆工的岗位职责
2014/03/17 职场文书
赞美老师的演讲稿
2014/05/22 职场文书
关于旅游的活动方案
2014/08/15 职场文书
租房协议书
2014/09/12 职场文书
小学体育跳绳课教学反思
2016/02/16 职场文书
MySQL基础快速入门知识总结(附思维导图)
2021/09/25 MySQL