最近写完小程序后, 开始学习React, 因为有编译器, 就直接用ES6 新语法了,
中间自然离不开 () => { console.log(‘箭头函数的this是指向哪的问题’)};
var obj2 = {
id: 2333,
test: () => console.log(this)
}
obj2.test();//window
obj2.test.call(obj2);//window
那么我要这里 test函数的this 指向 obj2 是要怎么做呢
来分析下上面代码, 转换成 ES5 写法的this指向:
var obj2 = {}; // window.obj2 = {};
obj2.id = 2333; // window.obj2 = { id: 2333; }
var _this = this;
obj2.test = function(){console.log(_this);}
用箭头函数时, this是指向 最初定义变量时的this, 即 window.obj2 的 window
改一下, 变得很复杂了
var obj2 = {
id: 2333,
test: function(){
(()=>{
console.log(this)
})()
}
}
obj2.test();//obj2
obj2.test.call(obj2);//obj2
其实还有一种写法:
function Obj(){
this.id = 2333;
this.test = () => console.log(this);
}
var obj2 = new Obj();
**************************************************
总结:
1. 箭头函数的this不能用call()或者apply()进行绑定
2. 箭头函数的 this
永远指向该函数构造时的环境。
... 现在还没再nodeJs环境中 用箭头函数, 只知道 浏览器的*对象是 window, node环境是 global , 后面深入学习node之后再总结..