JavaScript函数-函数的参数
在JavaScript编程语言中,函数是组织代码和实现复杂逻辑的基本单元。而函数参数则是这些功能的重要组成部分,它们允许我们将数据传递给函数,从而使得函数更加通用和灵活。本文将深入探讨JavaScript函数参数的各种特性及其最佳实践。
参数基础
定义与调用
在定义一个函数时,我们可以指定一个或多个参数。当调用这个函数时,我们需要提供相应数量的实参(实际参数),这些实参会按顺序赋值给形参(形式参数)。
function greet(name) {console.log('Hello, ' + name);
}greet('Alice'); // 输出: Hello, Alice
可选参数
在早期版本的JavaScript中,如果调用函数时提供的参数少于定义的参数,缺少的参数会被自动设置为undefined。从ES6开始,JavaScript引入了默认参数值,使处理可选参数变得更加容易:
function greet(name = 'Guest') {console.log('Hello, ' + name);
}greet(); // 输出: Hello, Guest
greet('Bob'); // 输出: Hello, Bob
剩余参数
剩余参数(rest parameters)是一个用于收集传递给函数的多余参数的机制。它允许我们将不定数量的参数表示为一个数组:
function sum(...args) {return args.reduce((acc, val) => acc + val, 0);
}console.log(sum(1, 2, 3)); // 输出: 6
console.log(sum(4, 5, 6, 7)); // 输出: 22
这与使用arguments对象不同,arguments是一个类数组对象,而剩余参数则是一个真正的数组,提供了更多的灵活性。
参数解构
ES6还引入了参数解构的功能,可以在函数参数中直接解构传入的对象或数组:
对象解构
function getUserInfo({name, age}) {console.log(`Name: ${name}, Age: ${age}`);
}const user = {name: 'Alice', age: 25};
getUserInfo(user); // 输出: Name: Alice, Age: 25
数组解构
function getFirstAndLast([first, ...rest]) {const last = rest.pop();console.log(`First: ${first}, Last: ${last}`);
}getFirstAndLast(['a', 'b', 'c', 'd']); // 输出: First: a, Last: d
使用arguments对象
虽然现在更推荐使用剩余参数,但在旧版JavaScript中,我们经常使用arguments对象来访问所有传递给函数的参数。需要注意的是,arguments并不是一个真正的数组,因此不支持数组的方法如push、pop等:
function showArguments() {for (let i = 0; i < arguments.length; i++) {console.log(arguments[i]);}
}showArguments(1, 2, 3); // 输出: 1, 2, 3
最佳实践
避免过多参数
尽量避免定义接受大量参数的函数,因为这样会使函数难以理解和维护。考虑使用对象来传递相关参数:
// 不推荐
function createPerson(name, age, job) {}// 推荐
function createPerson({name, age, job}) {}
使用默认参数值
利用默认参数值可以使函数更加健壮,并减少对未提供参数进行检查的需要。
注意参数类型
尽管JavaScript是动态类型语言,但明确参数的预期类型有助于提高代码的可读性和可靠性。考虑使用注释或工具如TypeScript来指定类型。
结语
感谢您的阅读!如果你有任何问题或想分享自己的见解,请在评论区留言交流!
相关文章:
JavaScript函数-函数的参数
在JavaScript编程语言中,函数是组织代码和实现复杂逻辑的基本单元。而函数参数则是这些功能的重要组成部分,它们允许我们将数据传递给函数,从而使得函数更加通用和灵活。本文将深入探讨JavaScript函数参数的各种特性及其最佳实践。 参数基础…...
Android TabLayout 实现随意控制item之间的间距
效果 红色标注是不同的间距。 实现方式 1、xml中定义 <com.google.android.material.tabs.TabLayoutandroid:id"id/tab_layout"android:layout_width"wrap_content"app:tabIndicatorColor"color/color_FF00B2E3"app:tabBackground"a…...
STM32的“Unique device ID“能否修改?
STM32F1系列的"Unique device ID"寄存器的地址为0x1FFFF7E8。 这个寄存器是只读的。 "Unique device ID"寄存器位于“System memory”中。“System memory”地址范围为“0x1FFF F000- 0x1FFF F7FF”。 所有STM32 MCU上都存在系统引导加载程序。顾名思义&a…...
STM32-温湿度上传OneNET项目
一、项目需求 使用 ESP8266 连接 OneNET 云平台,并通过 MQTT 协议上传 DHT11 获取的温湿度值。 二、项目框图 三、DHT11工作原理 参考于良许嵌入式手把手教你玩转DHT11(原理驱动) | 良许嵌入式 3.1 正常工作验证 # 上电后ÿ…...
前端面试-JavaScript 数据类型详解
目录 一、数据类型分类 二、核心区别对比 1. 存储方式 2. 比较方式 3. 类型检测方法 三、特殊类型详解 1. Symbol 2. BigInt 3. null vs undefined 四、常见面试扩展问题 五、总结 一、数据类型分类 JavaScript 数据类型分为 基本数据类型(原始类型&…...
【进程 】
【进程】 目录1. ELF格式程序与进程2. 进程的组织方式3. 进程的复刻(fork)4. 进程的状态 目录 1. ELF格式程序与进程 在Linux系统里,程序文件普遍采用ELF(Executable and Linkable Format)格式。这种格式的程序文件存…...
深入HBase——数据结构与算法
引入 通过前面的文章,我们对HBase已经有了基本认识,下面我们从HBase最核心的算法和数据结构进一步深入HBase。 HBase的一个列簇(Column Family)本质上就是一棵LSM树(Log-Structured Merge-Tree)。LSM树…...
Python爬虫实战:获取六图网漫画图
注意:以下内容仅供技术研究,请遵守目标网站的robots.txt规定,控制请求频率避免对目标服务器造成过大压力! 一、引言 Python 作为一种广泛应用于数据处理和网络爬虫领域的编程语言,拥有丰富的库和框架。其中,Scrapy 框架以其高效、灵活、可扩展等特点,成为构建爬虫程序的…...
HAProxy介绍与编译安装
目录 1、HAProxy介绍 2、HAProxy编译安装 Centos 基础环境 Ubuntu 基础环境 编译安装HAProxy 验证HAProxy版本 HAProxy启动脚本 配置文件 启动haproxy 验证haproxy状态 查看haproxy的状态页面 1、HAProxy介绍 HAProxy是法国开发者 威利塔罗(Willy Tarreau) 在2000年…...
全链路优化:如何让单点登录认证接口并发性能翻倍?
背景 最近针对一个单点登录认证项目进行性能优化,在 8核 16G 环境下的认证并发能力从每秒800次提升至每秒1600次,性能提升一倍,整理此次优化过程中的相关性能优化操作总结和大家分享一下。 Nginx配置优化 在并发认证场景下,Ngi…...
在Spring Boot中如何使用Freemaker模板引擎
在 Spring Boot 中使用 FreeMarker 模板引擎可以帮助你创建动态的 Web 页面。以下是详细的步骤和示例代码,介绍如何在 Spring Boot 项目里集成和使用 FreeMarker。 1. 添加依赖 如果你使用的是 Maven 项目,需要在 pom.xml 文件中添加 FreeMarker 相关依赖。Spring Boot 提供…...
Elasticsearch7.1.1 配置密码和SSL证书
生成SSL证书 ./elasticsearch-certutil ca -out config/certs/elastic-certificates.p12 -pass 我这里没有设置ssl证书密码,如果需要设置密码,需要再配置给elasticsearch 在之前的步骤中,如果我们对elastic-certificates.p12 文件配置了密码…...
个人简历html网页模板,科技感炫酷html简历模板
炫酷动效登录页 引言 在网页设计中,按钮是用户交互的重要元素之一。这样一款黑色个人简历html网页模板,科技感炫酷html简历模板,设计效果类似科技看板图,可帮您展示技能、任职经历、作品等,喜欢这种风格的小伙伴不要犹豫哦。该素材呈现了数据符号排版显示出人形的动画效…...
在LangFlow中集成OpenAI Compatible API类型的大语言模型
一、背景与核心价值 从Dify换到这个langflow真的时各种的不适应啊。 就比如这个OpenAI Compatible API,这不应该是基本操作嘛? 算了,服了,习惯了就好了。咱闲言少叙,正片开始: LangFlow作为LangChain的可视化开发工具,其最大优势在于无需编写代码即可构建复杂的大模型…...
Qt开发中有关内存管理方面常见的问题分析与解决方案
在Qt开发中,内存管理是一个既基础又关键的一部分知识。尽管Qt提供了自动化的父子对象管理机制,但在复杂的应用场景中(如多线程、动态UI、异步操作等),我们在开发过程中,仍可能遇到内存泄漏、野指针、重复释…...
【outOfMemoryError】排查思路与解决方案
前言 不好啦❗ 天塌了❗ 系统崩了❗ 快看啊,程序outOfMemoryError了🙈 我的心里活动:“哈哈哈😀哈哈哈😀终于给我碰上了,这个问题可很少发生啊,又积累一个问题。虽然我昨天发了版本࿰…...
Python蓝桥杯刷题-小数第n位详解
题目描述 我们知道,整数做除法时,有时得到有限小数,有时得到无限循环小数。 如果我们把有限小数的末尾加上无限多个 0,它们就有了统一的形式。 本题的任务是:在上面的约定下,求整数除法小数点后的第 n 位开…...
Ubuntu服务器 /data 盘需要手动挂载的解决方案
服务器 /data 盘需要手动挂载的解决方案 如果重启服务器后,发现 /data 盘 没有自动挂载,通常是因为: /etc/fstab 配置文件 没有正确设置 自动挂载。该磁盘 没有被正确识别,需要手动挂载。文件系统错误 导致挂载失败。 下面是解…...
无法打开包括文件: “crtdbg.h”: No such file or directory
目录 无效解决措施(重装WindowsSDK) 有效解决措施 创建环境变量 添加环境变量INCLUDE 添加环境变量LIB RC无法运行 问题现象描述 复制以下文件至Error路径 无效解决措施(重装WindowsSDK) 参考文献:94176676/227706449-a5222d7d-d8d2-4a19-addb-8f546e69786f…...
番茄工作法html实现
对比了deepseek-r1-online和本地部署的14b的版本,输出的输出的html页面。 在线满血版的功能比较强大,可以一次完成所有要求。14b版本的功能有一些欠缺,但是基本功能也是写了出来了。 input write a html named Pomodoro-clock which “hel…...
免费开源的WPS AI插件 察元AI助手:getSelectedText 与 resolveDocumentInput 的组合使用
摘要本篇聚焦 documentActions 中选区与全文的衔接。实现新助手时,应明确 sourceMode,并在无选区时是否允许回退全文,以避免误处理整篇公文。关键词选区;全文;sourceMode扩展阅读与维护提示本篇围绕「getSelectedText 与 resolveDocumentInpu…...
STM32寄存器驱动LED流水灯:从仿真到实物的全流程实践
1. 从零开始理解STM32寄存器编程 第一次接触STM32寄存器编程时,我完全被那些十六进制地址和位操作搞懵了。但后来发现,寄存器编程就像直接跟硬件对话,比库函数更接近芯片本质。想象一下,你面前有8个灯泡(LED࿰…...
60美元AI眼镜TikTok爆卖160万!中国品牌正在改写智能穿戴格局
在跨境电商的世界里,真正的爆款往往不是那些堆砌高端配置的“黑科技”,而是能够用极致性价比让前沿科技走进普通人生活的产品。最近,TikTok美区数码产品榜单上出现了一匹令人瞩目的黑马——一款售价仅60美元左右的AI智能眼镜,在一…...
阿里云国际站 LingduCloud零度云:高额返点,帮企业更省钱地走向全球
这几年,越来越多企业开始把业务往海外铺。可问题也很现实:想做全球化,成本不能太高,部署不能太慢,后续运维还不能太折腾。说白了,大家想要的不是“上云”两个字,而是花更合适的钱,把…...
2026年人工智能专业毕业论文降AI工具推荐:AI技术类论文怎么降AI
2026年人工智能专业毕业论文降AI工具推荐:AI技术类论文怎么降AI 研究生群里聊起AI率的问题,发现十个人里起码六七个都在用工具降。主流的选择其实就那几款,关键是选对了能省很多麻烦。 综合价格和效果,我主推嘎嘎降AI࿰…...
【向量搜索落地生死线】:EF Core 10中Embedding缓存穿透、维度错配、FP16截断这3类故障如何10分钟定位?
第一章:EF Core 10向量搜索扩展的架构演进与核心约束EF Core 10 向量搜索扩展并非简单叠加功能,而是对查询管道、模型元数据和提供程序抽象层的一次深度重构。其核心目标是在保持 LINQ 表达式树语义一致性的前提下,将向量相似性计算ÿ…...
从“Hello World”到控制硬件:用汇编语言点亮你的第一个LED灯(基于8086模拟器)
从“Hello World”到控制硬件:用汇编语言点亮你的第一个LED灯(基于8086模拟器) 当你在屏幕上打印出第一个"Hello World"时,那种成就感可能还停留在抽象的字符层面。但当你用汇编语言直接控制硬件,看到LED灯随…...
阿里通义Z-Image-Turbo WebUI图像生成:快速体验AI绘画的魅力
阿里通义Z-Image-Turbo WebUI图像生成:快速体验AI绘画的魅力 1. 快速入门指南 1.1 一键启动WebUI服务 对于初次接触AI绘画的用户,Z-Image-Turbo WebUI提供了最简单的启动方式。只需在终端执行以下命令: bash scripts/start_app.sh这个脚本…...
从FPGA探索到IC后端:我是如何用OpenROAD开启开源芯片设计之旅的
从FPGA到GDSII:一位工程师的开源芯片设计探索手记 第一次在屏幕上看到自己设计的电路变成硅片上的物理结构时,那种震撼感至今难忘。作为一名长期与FPGA打交道的硬件工程师,我习惯了在可编程逻辑的抽象世界里遨游,直到偶然接触到Op…...
Vivado FIR滤波器实战:从MATLAB仿真到FPGA上板,我的数据截位与时钟方案踩坑记录
Vivado FIR滤波器实战:从MATLAB仿真到FPGA上板的数据截位与时钟方案深度解析 当你在Vivado中完成FIR滤波器的基本设计后,真正的挑战才刚刚开始。作为一位经历过多次项目实战的FPGA开发者,我想分享那些在教科书和官方文档中很少提及的关键细节…...
