最近写完小程序后, 开始学习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之后再总结..