var obj={ birth:1995, getAge:function(year){ var that=this; function getAge(){ return new Date().getFullYear()-that.birth; } return getAge(); } }; var obj3={ birth:1997, getAge:function(){ return year=>year-this.birth; } }; var obj2={ birth:1996, getAge:()=>(y=>this.birth), }; console.log(obj.getAge(2018)); console.log(obj3.getAge()(2018)); console.log(obj2.getAge()(2018));
输出结果为: 23 21 undefined
第一种使用了一种 hack 方法规避了 this 的 bug,二三两种用的都是箭头函数,为什么二可行,而三不可行呢?
1
jinxinking007 OP 这排版可读性太低,提取关键部分就是 getAge:function(){ return year=>year-this.birth; }和 getAge:()=>(y=>this.birth),两者的区别
|
2
ysc3839 2018-07-23 17:57:46 +08:00 via Android
|
3
guomuzz 2018-07-23 19:24:22 +08:00
var obj3 = {
birth: 1997, getAge: function () { console.log(this) return year => year - this.birth; } }; var obj2 = { birth: 1996, getAge: () => { console.log(this) return y => this.birth }, }; 打印一下就知道了 |
4
DrugsZ 2018-07-24 09:17:55 +08:00
箭头函数的 this 是在函数创建的时候就锁定了不能更改了的,就算用 call,apply,bind 也不行会报错
|
5
zhzer 2018-07-24 11:06:40 +08:00
在 js 里的 json 对象,只是一层面向对象语法糖,相对来说不是特别严谨,箭头函数无法手动设定 this 也就无法适用这层修饰
|