iis服务器助手广告广告
返回顶部
首页 > 资讯 > 前端开发 > JavaScript >JavaScript中arrow函数的作用是什么
  • 190
分享到

JavaScript中arrow函数的作用是什么

2024-04-02 19:04:59 190人浏览 泡泡鱼
摘要

本篇文章为大家展示了javascript中arrow函数的作用是什么,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。我们先来按常规语法定义函数:function&nb

本篇文章为大家展示了javascript中arrow函数的作用是什么,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。

我们先来按常规语法定义函数:

function funcName(params) {
  return params + 2;
 }
funcName(2);
// 4

该函数使用箭头函数可以使用仅仅一行代码搞定!

var funcName = (params) => params + 2
funcName(2);
// 4

是不是很酷!虽然是一个极端简洁的例子,但是很好的表述了箭头函数在写代码时的优势。我们来深入了解箭头函数的语法:
(parameters) => { statements }

如果没有参数,那么可以进一步简化:
() => { statements }

如果只有一个参数,可以省略括号:
parameters => { statements }

如果返回值仅仅只有一个表达式(expression), 还可以省略大括号:
parameters => expression

// 等价于:
function (parameters){
 return expression;
}

现在你已经学会了箭头函数的语法,我们来实战一下。打开Chrome浏览器开发者控制台,输入:
var double = num => num * 2

我们将变量 double 绑定到一个箭头函数,该函数有一个参数 num , 返回 num * 2 。 调用该函数:

double(2);
// 4

double(3);
// 6

没有局部 this 的绑定

和一般的函数不同,箭头函数不会绑定 this 。 或则说箭头函数不会改变 this 本来的绑定。

我们用一个例子来说明:

function Counter() {
 this.num = 0;
}
var a = new Counter();

因为使用了关键字 new 构造,Count()函数中的 this 绑定到一个新的对象,并且赋值给 a 。通过 console.log 打印

a.num ,会输出0。 
console.log(a.num);
// 0

如果我们想每过一秒将 a.num 的值加1,该如何实现呢?可以使用 setInterval() 函数。

function Counter() {
 this.num = 0;
 this.timer = setInterval(function add() {
  this.num++;
  console.log(this.num);
 }, 1000);
}

我们来看一下输出结果:

var b = new Counter();
// NaN
// NaN
// NaN
// ...

你会发现,每隔一秒都会有一个 NaN 打印出来,而不是累加的数字。到底哪里错了呢?

首先使用如下语句停止 setInterval 函数的连续执行:
clearInterval(b.timer);

我们来尝试理解为什么出错:根据上一篇博客讲解的规则,首先函数 setInterval 没有被某个声明的对象调用,也没有使用 new 关键字,再之没有使用 bind , call 和 apply 。 setInterval 只是一个普通的函数。实际上 setInterval 里面的 this 绑定到全局对象的。我们可以通过将 this 打印出来验证这一点:

function Counter() {
 this.num = 0;
this.timer = setInterval(function add() {
  console.log(this);
 }, 1000);
}
var b = new Counter();

你会发现,整个 window 对象被打印出来。 使用如下命令停止打印:
clearInterval(b.timer);

回到之前的函数,之所以打印 NaN ,是因为 this.num 绑定到 window 对象的 num ,而 window.num 未定义。

那么,我们如何解决这个问题呢?使用箭头函数!使用箭头函数就不会导致 this 被绑定到全局对象。

function Counter() {
 this.num = 0;
 this.timer = setInterval(() => {
  this.num++;
  console.log(this.num);
 }, 1000);
}
var b = new Counter();
// 1
// 2
// 3
// ...

通过 Counter 构造函数绑定的 this 将会被保留。在 setInterval 函数中, this 依然指向我们新创建的 b 对象。

为了验证刚刚的说法,我们可以将 Counter 函数中的 this 绑定到 that , 然后在 setInterval 中判断 this 和 that 是否相同。

function Counter() {
 var that = this;
 this.timer = setInterval(() => {
  console.log(this === that);
 }, 1000);
}
var b = new Counter();
// true
// true
// ...

正如我们期望的,打印值每次都是 true 。最后,结束刷屏的打印:
clearInterval(b.timer);

总结

1.箭头函数写代码拥有更加简洁的语法;

2. 不会绑定 this 。

上述内容就是JavaScript中arrow函数的作用是什么,你们学到知识或技能了吗?如果还想学到更多技能或者丰富自己的知识储备,欢迎关注编程网JavaScript频道。

--结束END--

本文标题: JavaScript中arrow函数的作用是什么

本文链接: https://www.lsjlt.com/news/75942.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • JavaScript中arrow函数的作用是什么
    本篇文章为大家展示了JavaScript中arrow函数的作用是什么,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。我们先来按常规语法定义函数:function&nb...
    99+
    2024-04-02
  • JavaScript中函数的作用是什么
    本篇内容介绍了“JavaScript中函数的作用是什么”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成! ...
    99+
    2024-04-02
  • javascript中eval函数的作用是什么
    本篇文章给大家分享的是有关javascript中eval函数的作用是什么,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。(1)介绍javascript中的eval函数的用法(2)...
    99+
    2023-06-03
  • JavaScript eval()函数的作用是什么
    JavaScript的eval()函数的作用是将一个字符串作为脚本代码进行解析和执行。它可以动态地执行字符串中的JavaScript...
    99+
    2023-10-11
    JavaScript
  • JavaScript代码中的函数参数和副作用是什么
    这篇文章给大家介绍JavaScript代码之函数参数和副作用是什么,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。函数是JavaScript程序的重要组成部...
    99+
    2024-04-02
  • JavaScript中isPrototypeOf函数有什么作用
    本篇内容主要讲解“JavaScript中isPrototypeOf函数有什么作用”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“JavaScript中isPrototypeOf函数有什么作用”吧!...
    99+
    2023-06-25
  • javascript中的函数是指什么
    这篇文章主要讲解了“javascript中的函数是指什么”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“javascript中的函数是指什么”吧! ...
    99+
    2024-04-02
  • JavaScript 函数闭包的含义和作用是什么
    这篇文章主要讲解了“JavaScript 函数闭包的含义和作用是什么”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“JavaScript 函数闭包的含义和作用...
    99+
    2024-04-02
  • JavaScript中函数调用栈是怎么工作的
    这篇文章将为大家详细讲解有关JavaScript中函数调用栈是怎么工作的,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。合理地处理堆栈信息能使你清除无用的数据, 而只专注于...
    99+
    2024-04-02
  • JavaScript函数与作用域的使用方法是什么
    本篇内容介绍了“JavaScript函数与作用域的使用方法是什么”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所...
    99+
    2024-04-02
  • web中Math函数的作用是什么
    这篇文章将为大家详细讲解有关web中Math函数的作用是什么,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。  Math.round(3.6) //四舍五入  random() //返回0-1之间的随机数 ...
    99+
    2023-06-05
  • python中round()函数的作用是什么
    这篇文章给大家介绍python中round()函数的作用是什么,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。python的五大特点是什么python的五大特点:1.简单易学,开发程序时,专注的是解决问题,而不是搞明白语...
    99+
    2023-06-14
  • Python中pass函数的作用是什么
    这篇文章给大家介绍Python中pass函数的作用是什么,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。Python主要用来做什么Python主要应用于:1、Web开发;2、数据科学研究;3、网络爬虫;4、嵌入式应用开发...
    99+
    2023-06-14
  • Python中urlencode()函数的作用是什么
    这期内容当中小编将会给大家带来有关Python中urlencode()函数的作用是什么,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。python的数据类型有哪些python的数据类型:1. 数字类型,包括...
    99+
    2023-06-14
  • python中vars函数的作用是什么
    今天就跟大家聊聊有关python中vars函数的作用是什么,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。Python主要用来做什么Python主要应用于:1、Web开发;2、数据科学...
    99+
    2023-06-14
  • php中sort函数的作用是什么
    php中sort函数的作用是什么?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。php是什么语言php,一个嵌套的缩写名称,是英文超级文本预处理语言(PHP:Hypertext ...
    99+
    2023-06-14
  • PHP 中extract()函数的作用是什么
    这篇文章给大家介绍PHP 中extract()函数的作用是什么,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。代码如下:'' ASP/VBScript Dictionary extract' Au...
    99+
    2023-06-08
  • VBS中SetLocale函数的作用是什么
    今天就跟大家聊聊有关VBS中SetLocale函数的作用是什么,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。VBS文档中对SetLocale函数的描述: 设置全球区域设置,并返回以前...
    99+
    2023-06-08
  • PHP中ob_start()函数的作用是什么
    这篇文章给大家介绍PHP中ob_start()函数的作用是什么,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。比如你用得到服务器和客户端的设置信息,但是这个信息会因为客户端的不同而不同,如果想要保存phpinfo()函数...
    99+
    2023-06-17
  • PHP中str_replace函数的作用是什么
    这篇文章将为大家详细讲解有关PHP中str_replace函数的作用是什么,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。1、PHP函数str_replace只对needle使用数组。示例:s...
    99+
    2023-06-17
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作