JavaScript 箭头函数(Arrow Function) – JavaScript 完全手册(2018版)

栏目: JavaScript · 发布时间: 5年前

内容简介:小编推荐:

JavaScript 箭头函数(Arrow Function) – JavaScript 完全手册(2018版)

JavaScript 箭头函数(Arrow Function) – JavaScript 完全手册(2018版)

小编推荐: 掘金是一个面向 程序员 的高质量技术社区,从 一线大厂经验分享到前端开发最佳实践,无论是入门还是进阶,来掘金你不会错过前端开发的任何一个技术干货。

18 JavaScript 箭头函数(Arrow Function) – JavaScript 完全手册(2018版)

注:本文为 《 JavaScript 完全手册(2018版) 》第18节,你可以查看该手册的完整目录。

箭头函数(Arrow Function)是 ES6 / ES2015 中最具影响力的变化之一,现在它们被广泛使用。 它们与常规函数略有不同。 我们来看看下面的一些情况。

我前面已经介绍了箭头函数,但它们非常重要,它们需要再重点介绍一下。

在 ES6/ECMAScript2015 中引入了箭头函数,自从它们引入后,它们彻底改变了 JavaScript 代码写法(和工作方式)。

在我看来,这种变化非常受欢迎,你现在很少在现代代码库中看到 function 关键字。

在视觉上,这是一个简单而受欢迎的变化,您使用更短的语法编写函数,从:

const myFunction = function foo() {
  //...
}

变成:

const myFunction = () => {
  //...
}

如果函数体只包含一条语句,则可以省略括号,并在一行上写全部:

const myFunction = () => doSomething()

参数在括号中传递:

const myFunction = (param1, param2) => doSomething(param1, param2)

如果你只有一个参数,你甚至可以省略括号:

const myFunction = param => doSomething(param)

由于这种简短的语法,箭头函数 鼓励使用短函数

隐式返回

箭头函数允许您具有隐式返回,即返回值不必使用 return 关键字。

它在函数体内只有一个语句时有效:

const myFunction = () => 'test'

myFunction() //'test'

箭头函数中 this 如何工作

this 概念可能很难理解,因为它根据上下文的不同而变化,同事也受到 JavaScript 的模式(严格模式 strict mode 或非严格模式)的影响。

理清这个概念很重要,因为与常规函数相比, this 在箭头函数的表现有很大的不同。

当定义为对象的方法时,在常规函数中, this 指的是对象,因此您可以:

const car = {
  model: 'Fiesta',
  manufacturer: 'Ford',
  fullName: function() {
    return `${this.manufacturer} ${this.model}`
  }
}

调用 car.fullName() 将返回 “Ford Fiesta” 。

箭头函数的 this 作用域继承自执行期上下文。 箭头函数根本不绑定 this ,因此它的值将在调用栈中查找,因此在此代码中 car.fullName() 将不起作用,并将返回字符串 "undefined undefined"

const car = {
  model: 'Fiesta',
  manufacturer: 'Ford',
  fullName: () => {
    return `${this.manufacturer} ${this.model}`
  }
}

因此,箭头函数不适合作为对象方法使用。

在实例化对象时,箭头函数也不能用作构造函数。 它会引发 TypeError

当不需要动态上下文时,我们应该使用常规函数。

处理事件时也有类似的问题。 DOM 事件侦听器将 this 设置为目标元素,如果您在事件处理程序中依赖于 this ,则需要常规函数:

const link = document.querySelector('#link')
link.addEventListener('click', () => {
  // this === window
})

const link = document.querySelector('#link')
link.addEventListener('click', function() {
  // this === link
})

了解更多关于箭头函数的知识请查看 JavaScript 箭头函数:适用与不适用场景

如果你觉得本文对你有帮助,那就请分享给更多的朋友

关注「前端干货精选」加星星,每天都能获取前端干货

JavaScript 箭头函数(Arrow Function) – JavaScript 完全手册(2018版)

以上所述就是小编给大家介绍的《JavaScript 箭头函数(Arrow Function) – JavaScript 完全手册(2018版)》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

思考,快与慢

思考,快与慢

[美] 丹尼尔·卡尼曼 / 胡晓姣、李爱民、何梦莹 / 中信出版社 / 2012-7 / 69.00元

《纽约时报》2011年度十大好书 新书上市,连续20多周蝉联亚马逊、《纽约时报》畅销书排行榜前20名,上市至今超过7个月,横扫全球各大畅销书排行榜,稳居亚马逊总榜前50名 《经济学人》、《华尔街日报》、《卫报》、《纽约时报》、《金融时报》、《商业周刊》、《华盛顿邮报》、等国外权威媒体,《三联生活周刊》、《商学院》、《东方早报》等国内知名媒体争相报道,国内外读者好评如潮 人类究竟有......一起来看看 《思考,快与慢》 这本书的介绍吧!

HTML 压缩/解压工具
HTML 压缩/解压工具

在线压缩/解压 HTML 代码

正则表达式在线测试
正则表达式在线测试

正则表达式在线测试

HEX HSV 转换工具
HEX HSV 转换工具

HEX HSV 互换工具