箭头函数与普通函数:谁更胜一筹?

news2025/1/24 4:56:52

在这里插入图片描述

🤍 前端开发工程师(主业)、技术博主(副业)、已过CET6
🍨 阿珊和她的猫_CSDN个人主页
🕠 牛客高级专题作者、在牛客打造高质量专栏《前端面试必备》
🍚 蓝桥云课签约作者、已在蓝桥云课上架的前后端实战课程《Vue.js 和 Egg.js 开发企业级健康管理项目》、《带你从入门到实战全面掌握 uni-app》

文章目录

  • 一、引言
    • ❤介绍函数在编程中的重要性
    • ❤函数的定义和作用
    • ❤函数的重要性
    • ❤函数的应用
    • ❤总结
  • 二、箭头函数
    • 🤍定义
    • 🤍语法结构
    • 🤍自动绑定 this 关键字
    • 🤍简洁的语法
    • 🤍使用场景和示例
    • 🤍总结
  • 三、普通函数
    • 🥚定义
    • 🥚语法结构
    • 🥚函数调用
    • 🥚参数传递
    • 🥚返回值
    • 🥚作用域和闭包
    • 🥚使用场景和示例
    • 🥚总结
  • 四、箭头函数与普通函数的区别

一、引言

❤介绍函数在编程中的重要性

❤函数的定义和作用

  1. 定义:函数是一种将一组相关的代码封装在一起,并为其赋予一个名称的编程结构
  2. 作用:函数可以接受输入参数,并返回一个输出结果。

❤函数的重要性

  1. 代码复用:函数使得代码的复用成为可能。通过定义通用的函数,可以在不同的地方调用它们,避免了重复编写相同的代码。
  2. 抽象和封装:函数提供了一种抽象和封装的机制。它们将复杂的任务分解为较小的、独立的部分,使得代码更易于理解和维护。
  3. 模块化编程:函数有助于实现模块化编程。将代码划分为多个函数,可以更好地组织和管理代码,提高代码的可读性和可维护性。
  4. 逻辑分离:函数可以将相关的逻辑封装在一起,使代码的关注点分离。每个函数负责完成特定的任务,从而使代码更加清晰和易于理解。
  5. 提高可读性:通过使用有意义的函数名称和注释,可以提高代码的可读性。函数的封装和抽象也使得代码更容易被他人理解和修改。

在这里插入图片描述

❤函数的应用

  1. 算法和数据结构:函数常用于实现各种算法和数据结构,如排序、搜索和树等。
  2. 事件处理:在用户界面编程中,函数常用于处理用户事件,如点击、鼠标移动和键盘输入等。
  3. 业务逻辑:在应用程序中,函数用于实现业务逻辑和业务规则。

❤总结

函数在编程中扮演着至关重要的角色。它们提供了代码复用、抽象、封装和逻辑分离的能力,有助于提高代码的质量、可读性和可维护性。通过使用函数,程序员可以更高效地编写和组织代码,实现复杂的任务和业务逻辑。

二、箭头函数

🤍定义

箭头函数(Arrow Function)是 ES6 中引入的一种简洁的函数表达式语法
它使用 => 符号来定义函数,并且可以省略关键字如 functionreturn花括号

🤍语法结构

1. 基本语法:(param1, param2, ..., paramN) => expression

  • 参数:用圆括号括起来,可以有多个参数,用逗号分隔。
  • 返回值:使用 => 符号右侧的表达式表示函数的返回值。

2. 无参数的箭头函数:() => expression

  • 如果函数没有参数,可以省略圆括号。

3. 只有一个参数的箭头函数:param => expression

  • 如果函数只有一个参数,可以省略圆括号。

🤍自动绑定 this 关键字

箭头函数的一个重要特点是它会自动绑定 this 关键字
在箭头函数中,this 的值取决于它的上下文环境,而不是函数的调用方式。

🤍简洁的语法

箭头函数的语法非常简洁,减少了代码的冗余性。
它可以在一行中定义一个函数,并且可以省略关键字和花括号,使代码更加紧凑和易读。

🤍使用场景和示例

  1. 回调函数:箭头函数常用于作为回调函数,例如在事件处理、异步操作和迭代中
  2. 匿名函数:由于箭头函数的简洁性,它非常适合定义匿名函数,特别是在需要快速定义一个简单函数的情况下。

🤍总结

箭头函数是一种简洁的函数表达式语法,它使用 => 符号来定义函数,并可以省略关键字和花括号。箭头函数的特点包括自动绑定 this 关键字和简洁的语法。它常用于回调函数、匿名函数和需要快速定义简单函数的场景中。

三、普通函数

🥚定义

普通函数(Function)是一种用于执行特定任务或计算的可复用代码块
它接受输入参数,并通过执行一系列的语句来产生输出结果。

🥚语法结构

基本语法:

function name([param1, param2, ..., paramN]) {
  // 函数体
  [ statements; ]
  return [expression;]
}
  • 函数名:给函数赋予一个有意义的名称,用于调用函数。
  • 参数:用圆括号括起来,可以有多个参数,用逗号分隔。
  • 函数体:包含执行函数任务的代码语句。
  • 返回值:使用 return 关键字指定函数的返回值。如果没有返回值,可以省略 return 关键字。

🥚函数调用

通过使用函数名并在其后跟上圆括号中的参数来调用函数。
例如:functionName(param1, param2,...);

🥚参数传递

函数的参数可以是值、变量或表达式。
在函数调用时,将实际参数的值传递给函数的形式参数。

🥚返回值

函数可以通过 return 关键字返回一个值。
返回值可以是任何有效的 JavaScript 表达式。

🥚作用域和闭包

函数定义了自己的作用域,其中的变量和参数只能在函数内部访问。
闭包是指在函数内部创建的函数,能够访问到包含它的外部函数的变量和参数。

🥚使用场景和示例

  1. 计算和处理数据:普通函数可以用于执行数学计算、数据处理和转换等任务。
  2. 事件处理:在用户界面编程中,普通函数常用于处理用户事件,如点击、鼠标移动和键盘输入等。
  3. 业务逻辑:在应用程序中,普通函数用于实现业务逻辑和业务规则。

🥚总结

普通函数是一种可复用的代码块,它接受输入参数并通过执行一系列语句来产生输出结果。普通函数可以通过调用函数名并传递参数来执行。它们在编程中用于实现各种任务和逻辑,提供了代码复用和封装的能力。

四、箭头函数与普通函数的区别

以下是关于箭头函数与普通函数的区别的详细总结:

比较项箭头函数普通函数
语法结构(param1, param2, …, paramN) => expression

() => expression
function name([param1, param2, …, paramN]) {
[ statements; ]
return [expression;]
}
this 关键字自动绑定,取决于上下文环境取决于函数的调用方式
参数省略如果只有一个参数,可以省略圆括号
如果没有参数,可以省略圆括号和箭头 =>
必须使用圆括号来定义参数
花括号的使用不需要花括号来定义函数体需要花括号来定义函数体和包含语句
返回值使用箭头 => 右侧的表达式作为返回值
如果没有返回值,可以省略箭头 => 和表达式
使用 return 关键字来指定返回值
作用域和闭包没有自己的作用域,使用词法作用域
可以创建闭包,因为它们可以访问包含它们的外部函数的变量和参数
定义自己的作用域,其中的变量和参数只能在函数内部访问
可以创建闭包,通过在函数内部创建函数并访问外部函数的变量和参数
简洁性语法简洁,减少了代码的冗余性语法相对复杂,需要更多的关键字和结构

通过比较,我们可以看出箭头函数在语法上更加简洁,并且可以自动绑定 this 关键字。然而,普通函数提供了更多的灵活性和控制能力,适用于更复杂的场景。根据具体的需求和代码风格,选择合适的函数类型来实现所需的功能。

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

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

相关文章

数据结构 -- 图论之最小生成树

目录 1.最小生成树算法 1.Kruskal算法 2.Prim算法 1.最小生成树算法 定义:最小生成树算法:连通图有n个顶点组成,那么此时的图的每一个点都能相互连接并且边的个数为n-1条,那么此时该图就是最小生成树. 下面量算法有几个共同的特点: 1.只能使用图中权值最小的边来构造生成树 …

F. Magic Will Save the World

首先积攒了能量打了怪再积攒是没有意义的,可以直接积攒好,然后一次性进行攻击 那么怎么进行攻击了?可以尽量的多选怪物使用水魔法攻击剩余的再用火魔法进行攻击, 也就是只要存在合法的体积(即装入背包的怪物的体积之…

谷粒商城-商品服务三级分类功能·-后端代码

递归获取树形结构 CategoryController RequestMapping("/list/tree")public R list(){List<CategoryEntity> entities categoryService.listWithTree();return R.ok().put("data",entities);}CategoryServiceImpl 第一步&#xff1a; 1.查出所有分类…

MySQL 中的锁(三)

8.7. 死锁和空间锁 一般来说&#xff0c;只要有并发和加锁这两种情况的共同加持下&#xff0c;都会有死锁的身影。 死锁的具体成因&#xff0c;借用我们在并发编程中的内容&#xff1a; 8.7.1. 死锁 8.7.1.1. 概念 是指两个或两个以上的进程在执行过程中&#xff0c;由于竞…

史上最全接单平台集锦,程序员不容错过!

非典型程序员不是每天都累成狗&#xff0c;天天”996"甚至”007“。可能&#xff0c;面临着上班摸鱼没事干&#xff0c;下班躺尸打游戏的无聊境况。那么&#xff0c;如果你也是这样的程序员&#xff0c;有没有什么安排可以打发时间&#xff1f; 闲着还不如挣钱~心情好的时…

聚焦 6G 无线技术——目标和需求

从 3G 到 5G 乃至之后的每一种无线标准&#xff0c;都在设计时加入了推动行业发展的具体目标。例如&#xff0c;4G 专注于以 IP 为中心的灵活语音、数据和视频通信&#xff0c;而 5G 则在此基础上进行了改进。6G 的目标是提供更加无处不在、更高效、更身临其境的无线连接。6G 系…

记录一次YAMLException异常

记录一次YAMLException异常 ✅作者简介&#xff1a;大家好&#xff0c;我是Leo&#xff0c;热爱Java后端开发者&#xff0c;一个想要与大家共同进步的男人&#x1f609;&#x1f609; &#x1f34e;个人主页&#xff1a;Leo的博客 &#x1f49e;当前专栏&#xff1a; 报错以及B…

【从删库到跑路 | MySQL总结篇】表的增删查改(进阶下)

个人主页&#xff1a;兜里有颗棉花糖 欢迎 点赞&#x1f44d; 收藏✨ 留言✉ 加关注&#x1f493;本文由 兜里有颗棉花糖 原创 收录于专栏【MySQL学习专栏】&#x1f388; 本专栏旨在分享学习MySQL的一点学习心得&#xff0c;欢迎大家在评论区讨论&#x1f48c; 目录 一、联合…

Linux常用命令----touch命令

文章目录 Linux操作系统中&#xff0c;touch 命令是一个常用且强大的工具&#xff0c;主要用于创建空文件或设置文件的时间戳。本文将详细介绍 touch 命令的各种参数及其用法&#xff0c;并通过实例演示来加深理解。 1. touch命令基础 touch 命令的基本语法格式为&#xff1a…

鸿蒙4.0开发笔记之ArkTS装饰器语法基础@Extend扩展组件样式与stateStyles多态样式(十一)

一、Extend扩展组件样式 1、作用 前文提到可以使用Styles用于样式的扩展&#xff0c;在Styles的基础上&#xff0c;ArkTS语法还提供了Extend&#xff0c;⽤于扩展原生组件样式&#xff0c;包括Text、Button等等。 2、定义语法 Extend(UIComponentName) function functionNam…

Flutter下拉框使用和可替换按钮的组件

前言 1、下拉框 在使用flutter框架完成项目的时候&#xff0c;有一个下拉框选择排序条件的需求&#xff0c;需要将下拉的选择内容&#xff0c;放在下拉按钮的下面&#xff0c;如Unity的Dropdown。下图是完整的需求。但是flutter系统自带的DropdownButtonFormField&#xff0c…

RabbitMQ消息模型之Work Queues

Work Queues Work Queues&#xff0c;也被称为&#xff08;Task Queues&#xff09;&#xff0c;任务模型&#xff0c;也是官网给出的第二个模型&#xff0c;使用的交换机类型是直连direct&#xff0c;也是默认的交换机类型。当消息处理比较耗时的时候&#xff0c;可能生产消息…

pkpmbs 建设工程质量监督系统 文件上传漏洞复现

0x01 产品简介 pkpmbs 建设工程质量监督系统是湖南建研信息技术股份有限公司一个与工程质量检测管理系统相结合的&#xff0c;B/S架构的检测信息监管系统。 0x02 漏洞概述 pkpmbs 建设工程质量监督系统 FileUpOrDown.aspx、/Platform/System/FileUpload.ashx、接口处存在任意文…

编程实现bf算法

BF算法&#xff08;Brute Force算法&#xff09;是一种朴素的字符串匹配算法&#xff0c;其基本思想是在文本串中不断地比较模式串和文本串中的子串&#xff0c;直到找到匹配的位置或者搜索完整个文本串。 下面是用Python实现BF算法的代码&#xff1a; def bf_search(text, p…

vuepress-----8、自定义域名

# 8、自定义域名 购买域名 [外链图片转存中…(img-0XcE3Zjv-1701236952478)] 填写域名、https # 自定义域名

【机器学习 | 可视化系列】可视化系列 之 决策树可视化

&#x1f935;‍♂️ 个人主页: AI_magician &#x1f4e1;主页地址&#xff1a; 作者简介&#xff1a;CSDN内容合伙人&#xff0c;全栈领域优质创作者。 &#x1f468;‍&#x1f4bb;景愿&#xff1a;旨在于能和更多的热爱计算机的伙伴一起成长&#xff01;&#xff01;&…

基于SSM的航空票务推荐系统的设计与实现

末尾获取源码 开发语言&#xff1a;Java Java开发工具&#xff1a;JDK1.8 后端框架&#xff1a;SSM 前端&#xff1a;Vue 数据库&#xff1a;MySQL5.7和Navicat管理工具结合 服务器&#xff1a;Tomcat8.5 开发软件&#xff1a;IDEA / Eclipse 是否Maven项目&#xff1a;是 目录…

光伏、储能双层优化配置接入配电网研究(附带Matlab代码)

由于能源的日益匮乏&#xff0c;电力需求的不断增长等&#xff0c;配电网中分布式能源渗透率不断提高&#xff0c;且逐渐向主动配电网方向发展。此外&#xff0c;需求响应(demand response&#xff0c;DR)的加入对配电网的规划运行也带来了新的因素。因此&#xff0c;如何综合考…

UE 事件分发机制(二) day10

自定义事件分发机制 自建事件分发机制与结构 Unreal推荐的游戏逻辑开发流程 基于 Unreal推荐的游戏逻辑开发流程&#xff0c;一般我们的整体规划也就是这样 大致结构类图 创建接口类与管理类以及所需函数 新建一个Unreal接口类作为接口 然后创建一个蓝图函数库的基类 Ev…

适合大部分人可以做的兼职副业

大部分人每天八点上班&#xff0c;五点下班&#xff0c;日复一日地重复着枯燥的工作内容&#xff0c;关键是工资还不够花。那么&#xff0c;怎么才能增加日常收入、提高生活质量呢&#xff1f;副业兼职是个不错的赚钱选择。打工人除去日常工作&#xff0c;额外的空闲时间还是很…