博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
坑爹的箭头函数
阅读量:4314 次
发布时间:2019-06-06

本文共 720 字,大约阅读时间需要 2 分钟。

es6(es2015)中引入了箭头函数,形如

() => {    console.log('arrow function!');}// 相当于function() {    console.log('arrow function!');}

  

爱好新技术的我,当然是热情拥抱她,把所有的function 都用箭头取代了

然而这给我今天的开发带来的灾难性的打击,浪费了整整一下午时间终于发现他们之间其实还是有很大区别的,由于过分钟爱她,以致于始终不愿意相信是她出了问题。

出问题的代码如下:

watch: {    'calendar.value': (value) => {        this.calendar.items[this.calendar.picker].value = value;    }},

这是Vue组件中的一段代码, 对于Vue组件,this无处不在,方法中,钩子函数中,Watch选项中。。。

然而,在这段代码中this竟然指向了window对象,导致整个页面都出错了,功能瘫了大半。

百思不得其解,后来终于不得不承认是箭头函数出了问题,换成如下传统方式就解决了问题了

watch: {    'calendar.value': function(value) {        this.calendar.items[this.calendar.picker].value = value;    }},

 

万般感慨,深刻反思以后,写下此文以加深记忆,不能再浪费时间踩这个坑了。。。

  

转载于:https://www.cnblogs.com/yangfengitblog/p/5965445.html

你可能感兴趣的文章
PHP高级教程-文件
查看>>
数据分页处理系列之一:Oracle表数据分页检索SQL
查看>>
UVALive 6145 Version Controlled IDE(可持久化treap、rope)
查看>>
mysql 将两个有主键的表合并到一起
查看>>
底部导航栏-----FragmentTabHost
查看>>
在linux中安装jdk以及tomcat并shell脚本关闭启动的进程
查看>>
apk,task,android:process与android:sharedUserId的区别
查看>>
MySQL 同主机不同数据库之间的复制
查看>>
iPad编程
查看>>
php编程安全指南
查看>>
在每天黄金时刻将数据库中数据获取包装成Excel表
查看>>
SpringBoot中使用Shiro和JWT做认证和鉴权
查看>>
SpringMVC和Struts2区别比较
查看>>
如何获得被动收入,工资之外再拿一份钱
查看>>
在一个整数区间里产生一组不重复的随机数
查看>>
Java系列之:看似简单的问题 静态方法和实例化方法的区别
查看>>
大话设计模式(四)单例模式
查看>>
ACM-ICPC 2018 徐州赛区现场赛 I. Rikka with Sorting Networks (思维+DFS)
查看>>
tornado-websocket
查看>>
软件开发报价的计算方法
查看>>