什么是箭头函数?
箭头函数表达式的语法比函数表达式更简洁,并且没有自己的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
对象。
声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。
码云笔记 » 什么是箭头函数?
码云笔记 » 什么是箭头函数?