Arrow Function(箭头函数)是ES6新增的一种函数。
var x => x * x
上面的箭头函数相当于:
function (x) {
return x * x;
}
箭头函数相当于匿名函数,并且简化了函数定义。箭头函数有两种格式,一种像上面的,只包含一个表达式,连{ … }和return都省略掉了。
含多条语句时候就不能省略{ … }和return。
x => {
if (x > 0) {
return x * x;
}
else {
return - x * x;
}
}
如果参数是多个,需要用括号()括起来:
// 两个参数:
(x, y) => x * x + y * y
// 无参数:
() => 3.14
// 可变参数:
(x, y, ...rest) => {
var i, sum = x + y;
for (i=0; i<rest.length; i++) {
sum += rest[i];
}
return sum;
}
this
箭头函数看上去是匿名函数的一种简写,但实际上,箭头函数和匿名函数有个明显的区别:箭头函数内部的this是词法作用域,由上下文确定。
用了箭头函数,this就不指向window,而是父级;
不能使用arguments对象;
不能用作构造函数(不能使用new命令),否则抛错;
不能使用yield命令,因此箭头函数不能用作Generator函数。