es6中箭头函数 注意点

var aaabbb = 'kkkooo'
setTimeout(()=>{
    var aaaa = 'kkkk';
    console.log(this)
},1000);

因为据我了解,箭头函数指向是创建时候上下文的this指向,所以天真的认为上述函数中在箭头函数内部创建的变量aaaa也会在window对象中找到。可惜我错了。

*****************************************************************以上为问题再现**********************************************************************************************************

解释:箭头函数的特点:

箭头函数有几个使用注意点。

(1)函数体内的this对象,就是定义时所在的对象,而不是使用时所在的对象。

(2)不可以当作构造函数,也就是说,不可以使用new命令,否则会抛出一个错误。

(3)不可以使用arguments对象,该对象在函数体内不存在。如果要用,可以用 rest 参数代替。

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

就是第一点!!!

猜你喜欢

转载自www.cnblogs.com/aiyr/p/10120145.html