NodeJs 箭头函数:`()=>{}` 和 `()=>()` 的区别与使用场景

在 JavaScript 中,箭头函数(Arrow Function)是一种简洁的函数写法,它不仅可以减少代码量,还能避免 this 绑定的问题。然而,箭头函数有两种常见的写法:()=>{}()=>()。这两种写法虽然看起来很相似,但在实际使用中有一些关键区别。本文将详细解析它们的区别,并帮助你更好地理解如何选择合适的写法。


1. ()=>{}:块级作用域的箭头函数

语法

()=>{} 是一种带有块级作用域的箭头函数写法。函数体被包裹在 {} 中,可以包含多行代码。

返回值

  • 如果函数体使用 {},则需要在函数体内显式使用 return 语句来返回值。

  • 如果没有 return,函数默认返回 undefined

适用场景

适合需要执行多条语句或复杂逻辑的情况。

示例

const func1 = () => {console.log("Hello");return 42; // 显式返回 42};console.log(func1()); // 输出: Hello 42

如果没有 return,函数会返回 undefined


const func2 = () => {console.log("Hello");// 没有 return};console.log(func2()); // 输出: Hello undefined

2. ()=>():隐式返回的箭头函数

语法

()=>() 是一种隐式返回的箭头函数写法。函数体是一个表达式,用 () 包裹。

返回值

  • 函数会自动返回表达式的值,不需要显式写 return

  • 如果返回的是一个对象,需要用 () 包裹对象字面量,因为 {} 会被解释为函数体。

适用场景

适合单行逻辑或直接返回一个值的情况。

示例

const func3 = () => (42); // 隐式返回 42console.log(func3()); // 输出: 42

返回对象时需要用 () 包裹:


const func4 = () => ({ key: "value" }); // 隐式返回对象console.log(func4()); // 输出: { key: "value" }

3. 对比总结

| 特性 | ()=>{} | ()=>() |

|--------------------|------------------------------|------------------------------|

| 函数体 | 块级作用域 {} | 表达式 () |

| 返回值 | 需要显式 return | 隐式返回表达式的值 |

| 适用场景 | 多行逻辑或复杂操作 | 单行逻辑或直接返回值 |


4. 如何选择?

  • 使用 ()=>{} 的场景

- 函数体包含多行代码。

- 需要执行复杂的逻辑操作。

- 需要显式控制返回值。

  • 使用 ()=>() 的场景

- 函数体只有一行代码。

- 需要直接返回一个值或表达式。

- 代码需要更简洁的写法。


5. 实际应用示例

示例 1:多行逻辑


const calculate = (a, b) => {const sum = a + b;const product = a * b;return { sum, product }; // 返回一个对象};console.log(calculate(2, 3)); // 输出: { sum: 5, product: 6 }

示例 2:单行逻辑


const double = (x) => (x * 2); // 隐式返回console.log(double(5)); // 输出: 10

示例 3:返回对象


const createUser = (name, age) => ({name,age,isAdult: age >= 18,});console.log(createUser("Alice", 20)); // 输出: { name: "Alice", age: 20, isAdult: true }

6. 总结

()=>{}()=>() 是 JavaScript 中箭头函数的两种常见写法,它们的主要区别在于函数体的结构和返回值的方式。理解它们的区别后,你可以根据实际需求选择更合适的写法,从而编写出更简洁、高效的代码。

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

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

相关文章

缓存-Redis-缓存更新策略-主动更新策略-Cache Aside Pattern(全面 易理解)

**Cache-Aside Pattern(旁路缓存模式)**是一种广泛应用于缓存管理的设计模式,尤其在使用 Redis 作为缓存层时尤为常见。该模式通过在应用程序与缓存之间引入一个旁路,确保数据的一致性和高效性。本文将在之前讨论的 Redis 主动更新…

python制作翻译软件

本文复刻此教程:制作属于自己的翻译软件-很简单【Python】_哔哩哔哩_bilibili 一、明确需求(以搜狗翻译为例) (1)网址:https://fanyi.sogou.com/text (2) 数据:翻译内容…

【C++】20.二叉搜索树

文章目录 1. 二叉搜索树的概念2. 二叉搜索树的性能分析3. 二叉搜索树的插入4. 二叉搜索树的查找5. 二叉搜索树的删除6. 二叉搜索树的实现代码7. 二叉搜索树key和key/value使用场景7.1 key搜索场景:7.2 key/value搜索场景:7.3 主要区别:7.4 ke…

vue3探索——使用ref与$parent实现父子组件间通信

在vue3中,可以使用vue3的API defineExpose()函数结合ref或者$parent,实现父子组件数据的传递。 子组件向父组件传递数据defineExpose()和ref 子组件:通过defineExpose() 函数,向外暴露响应式数据或者方法 // src/components/son…

Opencv图片的旋转和图片的模板匹配

图片的旋转和图片的模板匹配 目录 图片的旋转和图片的模板匹配1 图片的旋转1.1 numpy旋转1.1.1 函数1.1.2 测试 1.2 opencv旋转1.2.1 函数1.2.2 测试 2 图片的模板匹配2.1 函数2.2 实际测试 1 图片的旋转 1.1 numpy旋转 1.1.1 函数 np.rot90(kl,k1),k1逆时针旋转9…

重温设计模式--13、策略模式

策略模式介绍 文章目录 策略模式介绍C 代码示例 策略模式是一种行为设计模式,它允许在运行时选择算法的行为。该模式将算法的定义和使用分离开来,使得算法可以独立于使用它的客户端而变化,提高了代码的灵活性和可维护性。 其主要包含以下几个…

计算机基础知识复习1.5

标记-清除算法:标记-清除分为标记 和清除 两个阶段,首先通过可达性分析,标记出所有需要回收的对象,然后统一回收所有被标记的对象。 复制算法:为了解决碎片空间的问题,出现了复制算法 将内存分成两块&…

SQL Server 中的覆盖索引

1. 覆盖索引的工作原理 当查询只涉及索引中已经包含的列时,SQL Server 可以直接使用索引来返回查询结果,而不需要回表到数据页去检索实际的数据行。覆盖索引因此能够显著减少 I/O 操作,提高查询效率。 例如,假设有一个表 Employ…

Golang开发-案例整理汇总

前言 CSDN的文章缺少一个索引所有文章分类的地方,所以手动创建这么一个文章汇总的地方,方便查找。Golang开发经典案例汇总 GoangWeb开发 GolangWeb开发- net/http模块 GolangWeb开发-好用的HTTP客户端httplib(beego) GolangWeb开发- Gin不使用Nginx部署Vue项目 Golang并发开…

交叉编译的核心原理与核心概念

什么是交叉编译? 交叉编译(Cross Compilation)是一种在一种计算机体系结构或操作系统(主机,Host)上生成另一种计算机体系结构或操作系统(目标,Target)上的可执行文件的过…

vue-codemirror定位光标位置并在光标处插入信息

业务场景:在代码编辑器外点击按钮,向代码编辑器内的光标处新增一条拼接好的信息。 getCursor方法: 官方文档: doc.getCursor(?start: string) → {line, ch} Retrieve one end of the primary selection. start is an optional string indicating which end of the select…

【GOOD】A Survey of Deep Graph Learning under Distribution Shifts

深度图学习在分布偏移下的综述:从图的分布外泛化到自适应 Northwestern University, USA Repository Abstract 图上的分布变化——训练和使用图机器学习模型之间的数据分布差异——在现实世界中普遍存在,并且通常不可避免。这些变化可能会严重恶化模…

『SQLite』解释执行(Explain)

摘要:本节主要讲解SQL的解释执行:Explain。 在 sqlite 语句之前,可以使用 “EXPLAIN” 关键字或 “EXPLAIN QUERY PLAN” 短语,用于描述表查询的细节。 基本语法 EXPLAIN 语法: EXPLAIN [SQLite Query]EXPLAIN QUER…

(一)使用 WebGL 绘制一个简单的点和原理解析

使用 WebGL 绘制一个简单的点,我们需要通过 WebGL 的管线来进行一系列的步骤。以下是实现的详细步骤和原理解析: WebGL 绘制点的基本步骤 初始化 WebGL 上下文 首先,我们需要获取 WebGL 上下文,这样才能进行所有的绘图操作。通常…

Vue路由跳转报错

说明:使用 Vue 的router.replace/push,若跳转到当前路由,控制台会报错如下:NavigationDuplicated: Avoided redundant navigation to current location 原因:Vue-router在3.1之后把$router.push()方法改为了Promise。所…

【Axure高保真原型】环形进度条(开始暂停效果)

今天和大家分享环形进度条(开始暂停效果)的原型模版,效果包括: 点击开始按钮,可以环形进度条开始读取,中部百分比显示环形的读取进度; 在读取过程中,点击暂停按钮,可以随…

Euler 21.10(华为欧拉)安装oracle19c-RAC

1. Euler 21.10安装oracle19c-RAC 1.1. 环境规划 1.1.1. 主机规划 hostname IP 实例名 hfdb90 192.168.40.90 hfdb1 hfdb91 192.168.40.90 hfdb2 系统版本 BigCloud Enterprise Linux For Euler 21.10 (GNU/Linux 4.19.90-2107.6.0.0100.oe1.bclinux.x86_64 x86_6…

【python】matplotlib(radar chart)

文章目录 1、功能描述和原理介绍2、代码实现3、效果展示4、完整代码5、多个雷达图绘制在一张图上6、参考 1、功能描述和原理介绍 基于 matplotlib 实现雷达图的绘制 一、雷达图的基本概念 雷达图(Radar Chart),也被称为蛛网图或星型图&…

(三)通过WebGL绘制一个简单的三角形来理解渲染管线

理解 WebGL 绘图原理的关键是了解它的渲染管线。WebGL 渲染管线实际上是由多个阶段组成的,每个阶段都有特定的任务,最终输出的是屏幕上的图像。为了让你能轻松理解这些原理,我将通过一个简单的例子来详细解释。 绘制一个简单的三角形 我们将…

【shell编程】报错信息:bash: bad file descriptor(包含6种解决方法)

大家好,我是摇光~ 在运行 Shell 脚本时,遇到 bash: bad file descriptor 错误通常意味着脚本尝试对一个无效或不可用的文件描述符(file descriptor)执行了读写操作。 以下是一些可能导致这个问题的原因、详细案例以及相应的解决…