IDC

深入理解JavaScript中的箭头函数

作者:admin 2021-08-21 我要评论

让我们深入研究一下箭头函数。 箭头函数不仅仅是编写简洁代码的捷径。它还具有非常特殊且有用的特性。 JavaScript 充满了我们需要编写在其他地方执行的小函数的...

在说正事之前,我要推荐一个福利:你还在原价购买阿里云、腾讯云、华为云服务器吗?那太亏啦!来这里,新购、升级、续费都打折,能够为您省60%的钱呢!2核4G企业级云服务器低至69元/年,点击进去看看吧>>>)

让我们深入研究一下箭头函数。

箭头函数不仅仅是编写简洁代码的“捷径”。它还具有非常特殊且有用的特性。

JavaScript 充满了我们需要编写在其他地方执行的小函数的情况。

例如:

  • arr.forEach(func) —— forEach 对每个数组元素都执行 func。
  • setTimeout(func) —— func 由内建调度器执行。
  • ……还有更多。

JavaScript 的精髓在于创建一个函数并将其传递到某个地方。

在这样的函数中,我们通常不想离开当前上下文。这就是箭头函数的主战场啦。

一、箭头函数没有 “this”

正如我们在 对象方法,"this" 一章中所学到的,箭头函数没有 this。如果访问 this,则会从外部获取。

例如,我们可以使用它在对象方法内部进行迭代:

  1. let group = { 
  2.   title: "Our Group"
  3.   students: ["John""Pete""Alice"], 
  4.  
  5.   showList() { 
  6.     this.students.forEach( 
  7.       student => alert(this.title + ': ' + student) 
  8.     ); 
  9.   } 
  10. }; 
  11.  
  12. group.showList(); 

这里 forEach 中使用了箭头函数,所以其中的 this.title 其实和外部方法 showList 的完全一样。那就是:group.title。

如果我们使用正常的函数,则会出现错误:

  1. let group = { 
  2.   title: "Our Group"
  3.   students: ["John""Pete""Alice"], 
  4.  
  5.   showList() { 
  6.     this.students.forEach(function(student) { 
  7.       // Error: Cannot read property 'title' of undefined 
  8.       alert(this.title + ': ' + student) 
  9.     }); 
  10.   } 
  11. }; 
  12.  
  13. group.showList(); 

报错是因为 forEach 运行它里面的这个函数,但是这个函数的 this 为默认值 this=undefined,因此就出现了尝试访问 undefined.title 的情况。

但箭头函数就没事,因为它们没有 this。

不能对箭头函数进行 new 操作

不具有 this 自然也就意味着另一个限制:箭头函数不能用作构造器(constructor)。不能用 new 调用它们。

箭头函数 VS bind

箭头函数 => 和使用 .bind(this) 调用的常规函数之间有细微的差别:

  • .bind(this) 创建了一个该函数的“绑定版本”。
  • 箭头函数 => 没有创建任何绑定。箭头函数只是没有 this。this 的查找与常规变量的搜索方式完全相同:在外部词法环境中查找。

二、箭头函数没有 “arguments”

箭头函数也没有 arguments 变量。

当我们需要使用当前的 this 和 arguments 转发一个调用时,这对装饰器(decorators)来说非常有用。

例如,defer(f, ms) 获得了一个函数,并返回一个包装器,该包装器将调用延迟 ms 毫秒:

  1. function defer(f, ms) { 
  2.   return function() { 
  3.     setTimeout(() => f.apply(this, arguments), ms) 
  4.   }; 
  5.  
  6. function sayHi(who) { 
  7.   alert('Hello, ' + who); 
  8.  
  9. let sayHiDeferred = defer(sayHi, 2000); 
  10. sayHiDeferred("John"); // 2 秒后显示:Hello, John 

不用箭头函数的话,可以这么写:

  1. function defer(f, ms) { 
  2.   return function(...args) { 
  3.     let ctx = this; 
  4.     setTimeout(function() { 
  5.       return f.apply(ctx, args); 
  6.     }, ms); 
  7.   }; 

在这里,我们必须创建额外的变量 args 和 ctx,以便 setTimeout 内部的函数可以获取它们。

三、总结

箭头函数:

  • 没有 this
  • 没有 arguments
  • 不能使用 new 进行调用
  • 它们也没有 super,但目前我们还没有学到它。我们将在 类继承 一章中学习它。

这是因为,箭头函数是针对那些没有自己的“上下文”,但在当前上下文中起作用的短代码的。并且箭头函数确实在这种使用场景中大放异彩。


本文转载自网络,原文链接:https://www.toutiao.com/i6906591811188425219/

版权声明:本文转载自网络,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。本站转载出于传播更多优秀技术知识之目的,如有侵权请联系QQ/微信:153890879删除

相关文章
  • 深入理解JavaScript中的箭头函数

    深入理解JavaScript中的箭头函数

  • 2020年12月超实用设计干货大合集

    2020年12月超实用设计干货大合集

  • 一篇文章教会你Arrow 时间库在项目中的

    一篇文章教会你Arrow 时间库在项目中的

  • 刚来的大兄弟在这个小问题上翻车了,你

    刚来的大兄弟在这个小问题上翻车了,你

腾讯云代理商
海外云服务器