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

在这里插入图片描述

🤍 前端开发工程师(主业)、技术博主(副业)、已过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.hqwc.cn/news/232194.html

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

相关文章

酷开科技:让体育迷的热情释放,让运动精神传递

在繁忙的生活节奏中,我们总是被各种琐事所困扰,很难抽出时间去享受运动带来的快乐,甚至很少有时间去观看一场体育赛事。而一场好的体育赛事带给体育爱好者的快乐往往来自于两方面,一是线下参与,感受现场带来的震撼&…

docker搭建node环境开发服务器

docker搭建node环境开发服务器 本文章是我自己搭建node环境开发服务器的过程记录,不一定完全适用所有人。根据个人情况,按需取用。 命名项目路径 为了方便cd到项目路径,将项目路径重命名,方便输入。 vim /etc/profile # 修改p…

R语言gWQS包在加权分位数和回归模型的应用

在流行病学研究中,相较于单一因素的暴露,多因素同时暴露的情况更为常见。传统模型在评价多因素联合暴露时存在数据维度高、多重共线性等问题. WQS 回归模型的基本原理是通过分位数间距及加权的方法,将多种研究因素的效应综合成为一个指数&…

7-22 龟兔赛跑

import java.util.Scanner; class Main {public static void main(String[] args) {Scanner scnew Scanner(System.in);int timesc.nextInt();sc.close();int wugui 0;//乌龟里程int tuzi 0;//兔子里程int tuzi_run0;int tuzi_rest0;int is_rest0;//是否需要休息:…

visual studio 2022 更改字体和大小

工具--->选项 文本编辑器 输出窗口

【Hadoop】集群资源管理器 YARN

一、yarn 简介 Apache YARN (Yet Another Resource Negotiator) 是 hadoop 2.x 引入的分布式资源管理系统。主要用于解决 hadoop 1.x 架构中集群资源管理和数据计算耦合在一起,导致维护成本越来越高的问题。 yarn主要负责管理集群中的CPU和内存 用户可以将各种服…

JS获取字符串里最长的回文字符串

方法一 使用双指针配合枚举 /*** param {string} s* return {string}*/ const longestPalindrome s > {const LEN s.lengthif (LEN < 2) {return s}let maxStr /*** param left * param right * returns */const findPalindrome (left, right) > {while (left &…

服务器数据恢复—V7000存储raid5崩溃导致上层卷无法使用的数据恢复案例

服务器数据恢复环境&#xff1a; 某品牌V7000存储中有一组由几十块硬盘组建的raid5阵列。上层操作系统为windows server&#xff0c;NTFS分区。 服务器故障&#xff1a; 有一块硬盘出现故障离线&#xff0c;热备盘自动上线替换离线硬盘。在热备盘上线同步数据的过程&#xff0c…

视频智能分析国标GB28181云平台EasyCVR加密机授权异常是什么原因?

国标GB28181视频汇聚/视频云存储/集中存储/视频监控管理平台EasyCVR能在复杂的网络环境中&#xff0c;将分散的各类视频资源进行统一汇聚、整合、集中管理&#xff0c;实现视频资源的鉴权管理、按需调阅、全网分发、云存储、智能分析等。 近期有用户选择使用加密机进行EasyCVR授…

kubernetes七层负载Ingress搭建(K8S1.23.5)

首先附上K8S版本及Ingress版本对照 Ingress介绍 NotePort&#xff1a;该方式的缺点是会占用很多集群机器的端口&#xff0c;当集群服务变多时&#xff0c;这个缺点就愈发的明显(srevice变多&#xff0c;需要的端口就需要多) LoadBalancer&#xff1a;该方式的缺点是每个servi…

linux用户组_创建_删除_修改

2.2.2 用户组 每个用户都有一个用户组&#xff0c;系统可以对一个用户组中的所有用户进行集中管理。不同Linux系统对用户组的规定有所不同&#xff0c;如Linux下的用户属于与它同名的用户组&#xff0c;这个用户组在创建用户时同时创建。 组的类型&#xff1a; 基本组&#x…

【Node.js】笔记整理 3 -npm

写在最前&#xff1a;跟着视频学习只是为了在新手期快速入门。想要学习全面、进阶的知识&#xff0c;需要格外注重实战和官方技术文档&#xff0c;文档建议作为手册使用 系列文章 【Node.js】笔记整理 1 - 基础知识【Node.js】笔记整理 2 - 常用模块【Node.js】笔记整理 3 - n…