ES6箭头函数
2018-05-31 本文已影响90人
夏知更
定义
ES6 允许使用“箭头”(=>)定义函数。
function handle(name){
return name;
}
等同于
let handle = name => name;
关于普通函数应该知道的
- js中的this是执行上下文,在普通函数中,this指向它的直接调用者;
- 在默认情况下(非严格模式,即没有使用'use strict;'),在全局环境下,js中的this指向window;
约定俗成,在全局环境下,js中的this指向window
- 在严格模式下,没有直接调用者的函数中的this是undefined;
如果使用“严格模式”,‘use strict’禁止this关键字指向全局对象,此时this为undefined
- 可以使用call,apply,bind函数绑定,此时this指向的是绑定的对象;
与普通函数之间的区别
1、函数体内的this对象,是定义时所在的对象,而不是使用时所在的对象;
简单而言,即箭头函数使用时,不绑定this对象,箭头函数没有自己的this,它的this是继承而来的,默认指向在定义箭头函数时所处的对象(宿主对象)。由于箭头函数没有自己的this,它所使用的this是外层代码块的this, 所以箭头函数可以方便地让我们在 setTimeout ,setInterval中方便的使用this。
不绑定this示例:
function handle () {
let obj = {
name:'andy',
age:18,
speakEnglish:function () {
console.log(this); //obj对象
return 'YES,I CAN';
},
talkToSomeBody:()=>{
console.log(this); //window对象
return 'NO';
}
};
console.log(obj.speakEnglish());
console.log(obj.talkToSomeBody());
}
handle();
运行结果
从运行结果中可以看出,普通函数的this是现在使用的对象,而箭头函数的this是之前定义的对象,所以箭头函数可以在会改变this指向的地方代替普通函数,比如各种callback回调函数;
2、不能当做构造函数,即不能使用new命令
this指向的固定化,并不是因为箭头函数内部有绑定this的机制,实际原因是箭头函数根本没有自己的this,导致内部的this就是外层代码块的this。正是因为它没有this,所以也就不能用作构造函数。
3、不可以使用arguments对象,该对象在函数体内不存在。如果要用,可以用 rest 参数代替
function foo() {
setTimeout(() => {
console.log('args:', arguments);
}, 100);
}
foo(2, 4, 6, 8)
// args: [2, 4, 6, 8]
箭头函数内部的变量arguments,其实是函数foo的arguments变量。
另外,由于箭头函数没有自己的this,所以当然也就不能用call()、apply()、bind()这些方法去改变this的指向。