箭头函数表达式的语法比函数表达式更简洁,并且没有自己的​​this​​​,​​arguments​​​,​​super​​​或​​new.target​​。箭头函数表达式更适用于那些本来需要匿名函数的地方,并且它不能用作构造函数。

//ES5 Version
var getCurrentDate = function (){
return new Date();
}

//ES6 Version
const getCurrentDate = () => new Date();

在本例中,ES5 版本中有​​function(){}​​​声明和​​return​​​关键字,这两个关键字分别是创建函数和返回值所需要的。在箭头函数版本中,我们只需要​​()​​​括号,不需要 ​​return​​ 语句,因为如果我们只有一个表达式或值需要返回,箭头函数就会有一个隐式的返回。

//ES5 Version
function greet(name) {
return 'Hello ' + name + '!';
}

//ES6 Version
const greet = (name) => `Hello ${name}`;
const greet2 = name => `Hello ${name}`;

我们还可以在箭头函数中使用与函数表达式和函数声明相同的参数。如果我们在一个箭头函数中有一个参数,则可以省略括号。

const getArgs = () => arguments

const getArgs2 = (...rest) => rest

箭头函数不能访问​​arguments​​​对象。所以调用第一个​​getArgs​​函数会抛出一个错误。相反,我们可以使用rest参数来获得在箭头函数中传递的所有参数。

const data = {
result: 0,
nums: [1, 2, 3, 4, 5],
computeResult() {
// 这里的“this”指的是“data”对象
const addAll = () => {
return this.nums.reduce((total, cur) => total + cur, 0)
};
this.result = addAll();
}
};

箭头函数没有自己的​​this​​​值。它捕获词法作用域函数的​​this​​​值,在此示例中,​​addAll​​​函数将复制​​computeResult​​​ 方法中的​​this​​​值,如果我们在全局作用域声明箭头函数,则​​this​​​值为 ​​window​​ 对象。