从0开始学习JavaScript--JavaScript 箭头函数

在这里插入图片描述

JavaScript的现代语法,箭头函数(Arrow Functions)是一个不可忽视的重要部分。它们不仅提供了更简洁的语法,还改变了函数的作用域规则。在这篇文章中,将深入研究JavaScript箭头函数的概念、语法、用法以及它们与传统函数表达式的区别。

什么是箭头函数?

箭头函数是ES6(ECMAScript 2015)引入的一种新的函数语法。它们提供了一种更简短的语法来声明函数,并且具有词法作用域的特性,即它们继承了父级作用域的this值。让我们通过一些例子来深入了解箭头函数的基本语法。

基本语法

// 传统函数表达式
const add = function(a, b) {return a + b;
};// 箭头函数
const addArrow = (a, b) => a + b;console.log(add(2, 3));      // 输出: 5
console.log(addArrow(2, 3)); // 输出: 5

在这个例子中,我们分别使用传统函数表达式和箭头函数来声明一个简单的加法函数。箭头函数的语法更为简洁,尤其适用于短小的函数体。

词法作用域

箭头函数具有词法作用域,这意味着它们继承了父级作用域的this值。看下面的例子:

function Counter() {this.count = 0;// 传统函数表达式setInterval(function() {this.count++;console.log('Traditional:', this.count);}, 1000);// 箭头函数setInterval(() => {this.count++;console.log('Arrow:', this.count);}, 1000);
}const counter = new Counter();

在传统函数表达式中,setInterval 中的函数会创建一个新的this值,导致this.count无法正确访问。而在箭头函数中,它会继承Counter函数的this值,使得this.count能够正确递增。

箭头函数的用法

1. 简化函数体

箭头函数在函数体较为简单的情况下能够提供更简洁的语法:

// 传统函数表达式
const square = function(x) {return x * x;
};// 箭头函数
const squareArrow = x => x * x;console.log(square(5));      // 输出: 25
console.log(squareArrow(5)); // 输出: 25

2. 没有this绑定

在箭头函数中,不存在this绑定的问题,它会捕获所在上下文的this值:

function Person() {this.age = 0;// 传统函数表达式setInterval(function growUp() {this.age++;console.log('Traditional:', this.age);}, 1000);// 箭头函数setInterval(() => {this.age++;console.log('Arrow:', this.age);}, 1000);
}const person = new Person();

在传统函数表达式中,growUp 函数的this值会变为window,导致this.age无法正确访问。而在箭头函数中,它会正确地捕获Person对象的this值。

3. 更简洁的返回语句

当函数体只有一个表达式时,箭头函数可以省略花括号并且自动返回表达式的值:

// 传统函数表达式
const multiply = function(a, b) {return a * b;
};// 箭头函数
const multiplyArrow = (a, b) => a * b;console.log(multiply(2, 3));      // 输出: 6
console.log(multiplyArrow(2, 3)); // 输出: 6

4. 适用于回调函数

箭头函数在处理回调函数时尤其方便,因为它们不会创建新的this值,避免了传统函数表达式中需要使用bind或者that等方式来确保正确的this值。

const numbers = [1, 2, 3, 4, 5];// 传统函数表达式
const squared1 = numbers.map(function(n) {return n * n;
});// 使用箭头函数
const squared2 = numbers.map(n => n * n);console.log(squared1); // 输出: [1, 4, 9, 16, 25]
console.log(squared2); // 输出: [1, 4, 9, 16, 25]

在这个例子中,箭头函数更加简洁,避免了传统函数表达式中的冗余代码。

箭头函数与传统函数表达式的区别

1. 没有arguments对象

箭头函数没有自己的arguments对象,它继承自父级作用域。这可能导致一些潜在的问题,因为修改箭头函数中的arguments会影响到父级作用域。

function traditionalFunction() {setTimeout(function() {console.log(arguments); // 输出: [1, 2, 3]}, 100);
}function arrowFunction() {setTimeout(() => {console.log(arguments); // 输出: Uncaught ReferenceError: arguments is not defined}, 100);
}traditionalFunction(1, 2, 3);
arrowFunction(1, 2, 3);

在箭头函数中,尝试访问arguments会导致Uncaught ReferenceError。如果需要使用参数,可以使用剩余参数语法...args

2. 没有prototype属性

箭头函数没有prototype属性,因此无法作为构造函数使用,不能通过new关键字来实例化。

const TraditionalConstructor = function() {};
const ArrowConstructor = () => {};const instance1 = new TraditionalConstructor(); // 正常
const instance2 = new ArrowConstructor(); // 报错: ArrowConstructor is not a constructor

3. 不能用作Generator函数

传统函数表达式可以通过function*语法声明Generator函数,而箭头函数不支持这种语法。

function* traditionalGenerator() {yield 1;
}const arrowGenerator = function*() { // 正确yield 1;
};const arrowGeneratorError = *() => { // 报错: Unexpected token '*'yield 1;
};

总结

在本文中,深入研究了JavaScript箭头函数的概念、语法和用法。箭头函数不仅提供了更简洁的语法,还解决了传统函数表达式中this值的问题。我们探讨了箭头函数在不同场景下的应用,包括简化函数体、避免this绑定问题以及作为回调函数的方便性。

然而,也强调了箭头函数与传统函数表达式之间的一些区别,如缺少arguments对象、没有prototype属性以及不能作为Generator函数使用等。在实际项目中,合理选择箭头函数或传统函数表达式取决于具体的需求和上下文。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/204540.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

docker容器运维操作命令

docker exec :在运行的容器中执行命令 docker exec [OPTIONS] CONTAINER COMMAND [ARG...] OPTIONS说明: -d :分离模式: 在后台运行 -i :即使没有附加也保持STDIN 打开 -t :分配一个伪终端docker ps : 列出容器 docker ps [OPTIONS] OPTIONS说明&#…

Javaweb之Vue组件库Element之Dialog对话框的详细解析

4.3.3 Dialog对话框 4.3.3.1 组件演示 Dialog: 在保留当前页面状态的情况下,告知用户并承载相关操作。其企业开发应用场景示例如下图所示 首先我们需要在ElementUI官方找到Dialog组件,如下图所示: 然后复制如下代码到我们的组件文件的templ…

快速了解Spring AOP的概念及使用

文章目录 1. AOP概念1.1 什么是AOP?1.2 什么是Spring AOP? 2. Spring AOP的使用2.1 引入Spring AOP依赖2.2 编写AOP程序 3. Spring AOP详解3.1 Spring AOP核心概念1. 切点(Pointcut)2. 连接点(Join Point)3…

Spring Boot + MyBatis-Plus实现数据库读写分离

文章目录 1. 引言2. MyBatis-Plus简介3. 准备工作4. 配置数据源5. 配置MyBatis-Plus6. 创建实体类和Mapper接口7. 编写Service8. 控制器层9. 测试10. 数据库读写分离的原理11. 拓展11.1. 动态数据源11.2. 多数据源事务管理11.3. 多租户支持 12. 总结 🎉Spring Boot …

图书管理系统源码,图书管理系统开发,图书借阅系统源码配置和运行图解源码已附加

目录 配置简介和软件条件 数据库附件配置 vs应用程序web.config配置数据库链接字符串 数据库文件脚本代码 配置简介和软件条件 所需要的软件是Vs2017以上数据库是Sqlserver2012以上,如果数据库附件不了可以使用数据库脚本附件数据库脚本会在文章末尾写出来。可以…

鸿蒙开发-ArkTS 语言-循环渲染

[写在前面: 文章多处用到gif动图,如未自动播放,请点击图片] 衔接上一篇: 鸿蒙开发-ArkTS 语言-状态管理 4. 渲染控制 对于 UI 渲染,可以基于数据结构选择一些内置方法(例如:ForEach)快速渲染 UI 结构。 …

SpringBoot+VUE3前后端分离-【支付宝支付】

1、支付宝沙箱应用申请 https://open.alipay.com/develop/sandbox/app 打开支付宝沙箱能够看到如下信息: 获取到appid; 2、获取应用私钥以及支付宝公钥 在接口加密方式选择公钥模式启用,根据操作即可获取应用公钥、应用私钥以及支付宝公钥…

Redis 主库挂了,如何不间断服务?

目录 1、哨兵机制的基本流程 2、主观下线和客观下线 3、如何选定新的主库? 总结 // 你只管前行,剩下的交给时间 在 reids 主从库集群模式下,如果从库发生故障了,客户端可以继续向主库或其他从库发送请求,进行相关的…

5W2H分析法

5W2H分析法 5W2H分析法又叫七问分析法。 模型介绍 简单、方便,易于操作的思考(框架)模型,问题分析模型,它可以帮助我们保证思考的严谨与全面,也能给人启发,有着广泛的应用: 提问-可…

Spring之AOP理解与应用(更新中)

1. AOP的认识 面向切面编程:基于OOP基础之上新的编程思想,OOP面向的主要对象是类,而AOP面向的主要对象是切面,在处理日志、安全管理、事务管理等方面有非常重要的作用。AOP是Spring中重要的核心点,AOP提供了非常强…

别太担心,人类只是把一小部分理性和感性放到了AI里

尽管人工智能(AI)在许多方面已经取得了重大进展,但它仍然无法完全复制人类的理性和感性。AI目前主要侧重于处理逻辑和分析任务,而人类则具有更复杂的思维能力和情感经验。 人类已经成功地将一些可以数据化和程序化的理性和感性特征…

音频采集的相关基础知识

本文引注: https://zhuanlan.zhihu.com/p/652629744 1.麦克风的种类 (1)模拟麦克风 ECM麦克风:驻极体电容麦克风(ECM),典型的汽车ECM麦克风是一种将ECM单元与小型放大器电路整合在单个外壳中的装置。放大器提供一个模拟信号,其电压电平允许…

迷你洗衣机哪个牌子好又实惠?口碑最好的小型洗衣机

不得不说洗衣机的发明解放了我们的双手,而我们从小到大就有这个意识,贴身衣物不可以和普通的衣服一起丢进去洗衣机一起,而内衣裤上不仅有肉眼看见的污渍还有手上根本无法消灭的细菌,但是有一款专门可以将衣物上的细菌杀除的内衣洗…

简介vue

目录 一、介绍 渐进式框架​ 单文件组件​ 选项式 API (Options API)​ 组合式 API (Composition API)​ 该选哪一个?​ 创建一个 Vue 应用 应用实例​ 根组件​ DOM 中的根组件模板 应用配置​ 多个应用实例​ 一、介绍 Vue (发音为 /vjuː/&#xff…

CI/CD 构建中能保护好 SSHKEY吗?

目录 背景 方案 编码存储 逐行存储 合并存储 打马赛克 结论 背景 使用极狐GitLab CI/CD,在部署方面,主要有两种方式: 部署到K8S集群 Push模式:流水线通过kubectl执行命令部署,这需要把K8S的权限给流水线&#xf…

2. 两数相加

给你两个 非空 的链表,表示两个非负的整数。它们每位数字都是按照 逆序 的方式存储的,并且每个节点只能存储 一位 数字。 请你将两个数相加,并以相同形式返回一个表示和的链表。 你可以假设除了数字 0 之外,这两个数都不会以 0 …

C#面向对象

过程类似函数只能执行没有返回值 函数不仅能执行,还可以返回结果 1、面向过程 a 把完成某一需求的所有步骤 从头到尾 逐步实现 b 根据开发需求,将某些 功能独立 的代码 封装 成一个又一个 函数 c 最后完成的代码就是顺序的调用不同的函数 特点 1、…

vue项目多个不同的服务器请求地址管理

vue项目多个不同的服务器请求地址管理 在vue项目开发过程中,获取不同的数据可能会出现需要请求多个不同服务器地址的域名,这个时候需要对不同域名的请求地址进行管理以及跨域的代理。 一、单服务器域名地址的跨域代理和请求配置: 跨域配置&…

【算法萌新闯力扣】:卡牌分组

力扣热题:卡牌分组 一、开篇 今天是备战蓝桥杯的第22天。这道题触及到我好几个知识盲区,以前欠下的债这道题一并补齐,哈希表的遍历、最大公约数与最小公倍数,如果你还没掌握,这道题练起来! 二、题目链接:…

为Oracle链接服务器使用分布式事务

1 现象 在SQL Server中创建指向Oracle的链接服务器,SQL语句在事务中向链接服务器插入数据。返回链接服务器无法启动分布式事务的报错。 2 解决 在Windows平台下,SQL Server依赖分布式事务协调器(MSDTC)来使用分布式事务&#xff0…