箭头函数表达式的语法比函数表达式更简洁,并且没有自己的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对象。
Was this helpful?
0 / 0