遇事不决箭头函数?别期望“万金油”语法

开发 前端
事实上,箭头函数并不一定能解决编写JavaScript函数时的每一项需求。“万金油”函数是奢谈,下面就让我们深入探讨几个箭头函数不能解决的情况吧。

本文转载自公众号“读芯术”(ID:AI_Discovery)

ES6箭头函数似乎是一种很上瘾的函数,一旦了解你很容易用到停不下来。作为2015年ECMAScript 6更新的一部分,箭头函数有充分理由迅速流行。箭头函数语法是极好的语法糖,能解决很多需求:

  • 函数关键字
  • 花括号
  • return关键字(对于单行函数)

此外,箭头函数还降低了JavaScript的函数范围以及this关键字的部分复杂性,因为有时真正需要的只是一个匿名函数。

[[324242]]

但事实上,箭头函数并不一定能解决编写JavaScript函数时的每一项需求。“万金油”函数是奢谈,下面就让我们深入探讨几个箭头函数不能解决的情况吧。

对象原型

先看JavaScript代码片段:

  1. classRobot { 
  2.        constructor(name,catchPhrase) { 
  3.          this.name= name; 
  4.          this.catchPhrase= catchPhrase; 
  5.        } 
  6.      }; 
  7.      Robot.prototype.speak= () => { 
  8.        console.log(this === window); 
  9.        return this.catchPhrase 
  10.      }; 
  11.      const ironG =newRobot("Iron Giant", "Be good"); 
  12.      ironG.speak(); 

第15行的函数调用如下:

  1. true 
  2. undefined 

定义了speak() 原型函数,并为新Robot对象传递了口号,那为什么这段代码的计算结果是未定义的呢?

console.log()揭示了原因。如你所见,当要求控制台判断(this === window)时,它返回true。这为上文对象方法示例中讨论的内容提供了依据。

当使用需要上下文的函数时,必须使用常规函数语法,以便使this正确绑定:

  1. Robot.prototype.speak=function() { 
  2.                       console.log(this === ironG); // true 
  3.                       return this.catchphrase; 
  4.                     }; 

对象方法

假设想要创建一个绑定到对象的方法。

  1. const mario = { 
  2.          lives: 3, 
  3.          oneUp: () => { 
  4.              this.lives++; 
  5.          } 
  6.      } 

这个例子中,如调用mario.oneUp(),mario.lives的值应该从3增加到4。然而,按照目前所写的代码,无论调用多少次oneUp(), lives的值都将保持不变。

为什么?正是因为this!

正如MDN所述:箭头函数自身没有this。使用了封闭词法范围的this值;箭头函数遵循正常的变量查找规则。因此,当搜索当前作用域中不存在的this时,箭头函数最终会从其封闭作用域中找到this。

例子中,封闭的范围是window对象。调用oneUp()会要求程序增加window对象中lives的值。这样的值不存在,所以代码不起作用。

相反,应该使用传统的函数语法,它将函数的this绑定到调用该函数的特定对象上:

  1. const mario = { 
  2.        lives: 3, 
  3.        oneUp: function() { 
  4.          this.lives++; 
  5.        } 
  6.      }; 

动态上下文

最后一个例子:

  1. const button = document.querySelector(#darkMode); 
  2.                                 button.addEventListener('click', () => { 
  3.                                   this.classList.toggle('on'); 
  4.                                 }); 

到目前为止,你可能已经意识到这个代码无效及其原因。没错,这又和this有关。

箭头函数语法在函数声明时静态地绑定上下文,这与使用事件处理程序或事件监听器时试图实现的相反,它们本质上是动态的。

当通过事件处理程序或监听器操作DOM时,触发的事件指向属于目标元素的this。

对于全局执行上下文中定义的箭头函数,this将指向window。因此,上面的代码中,this.classList将被认为是window.classList,从而导致TypeError。

 

[[324243]]

 

 

图源:unsplash

 

从这几个简单的例子中可以发现,JavaScript中关于this的内容值得研究,这也许会加深你对何时使用或不使用箭头函数的理解。

 

责任编辑:赵宁宁 来源: 读芯术
相关推荐

2020-11-02 17:34:22

数据分析人工智能技术

2023-06-30 07:19:25

电源供电显卡

2023-10-24 08:01:38

String传统

2021-06-29 07:19:06

Redis容器化K8S

2021-06-29 15:39:16

容器技术Redis

2021-01-28 14:41:08

麦肯锡数字化项目

2021-12-15 10:20:08

缓存架构开发

2018-07-01 08:34:09

缓存数据服务

2022-06-07 17:01:31

UI框架前端

2013-02-22 09:43:41

面向对象面向对象编程

2023-08-01 16:21:44

模型AI

2017-09-04 16:20:38

Linuxshell命令

2021-11-08 11:21:18

redis 淘汰算法

2021-06-16 09:30:06

深度学习编程人工智能

2020-09-24 10:03:54

Python开发语言

2019-04-30 13:54:55

大数据Hadoop数据清洗

2023-02-16 08:03:06

2015-08-03 13:36:40

Docker技术优势应用场景

2022-06-08 10:01:06

Go语法PHP

2021-03-04 07:58:05

量子通信量子科技组网
点赞
收藏

51CTO技术栈公众号