- 前言
- 关于 ECMASCRIPT 发展史和现状
- ES6 带来的重大特性
- ES2016(ES7)的改进
- ES2017(ES8)带来的重大新特性
- ES2018(ES9)带来的重大新特性
- JavaScript 编码风格指南
- JavaScript 词法结构(构建块)
- JavaScript 变量
- JavaScript 数据类型
- JavaScript 表达式
- 原型继承
- 如何使用 JavaScript 中的 Classes(类)
- JavaScript 异常处理
- JavaScript 中的分号(;)
- JavaScript 中的引号
- JavaScript 字面量模板(Template Literals)指南
- JavaScript 中的 function(函数)
- JavaScript 箭头函数(Arrow Function)
- JavaScript 中的闭包(Closures)
- JavaScript 数组(Arrays)
- JavaScript 中的循环(Loops)
- JavaScript 中的事件(Events)
- JavaScript 中的事件循环(Event Loop)
- JavaScript 异步编程和回调
- 理解 JavaScript 中的 Promises
- 用 async 和 await 编写现代 JavaScript 异步代码
- JavaScript 中的 循环(Loops) 和 作用域(Scope)
- JavaScript 定时器 setTimeout() 和 setInterval()
- JavaScript 中的 this
- JavaScript 严格模式(Strict Mode)
- JavaScript 中的 立即执行函数表达式(IIFE)
- JavaScript 中的数学运算符
- JavaScript 中的 Math 对象
- 介绍 ES Modules(模块)
- 介绍 CommonJS
- JavaScript 术语表
JavaScript 箭头函数(Arrow Function)
18 JavaScript 箭头函数(Arrow Function) – JavaScript 完全手册(2018 版)
箭头函数(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 箭头函数:适用与不适用场景
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论