当前位置: 首页 > news >正文

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并不是一个真正的数组,因此不支持数组的方法如pushpop等:

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编程语言中&#xff0c;函数是组织代码和实现复杂逻辑的基本单元。而函数参数则是这些功能的重要组成部分&#xff0c;它们允许我们将数据传递给函数&#xff0c;从而使得函数更加通用和灵活。本文将深入探讨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 云平台&#xff0c;并通过 MQTT 协议上传 DHT11 获取的温湿度值。 二、项目框图 三、DHT11工作原理 参考于良许嵌入式手把手教你玩转DHT11&#xff08;原理驱动&#xff09; | 良许嵌入式 3.1 正常工作验证 #​ 上电后&#xff…...

前端面试-JavaScript 数据类型详解

目录 一、数据类型分类 二、核心区别对比 1. 存储方式 2. 比较方式 3. 类型检测方法 三、特殊类型详解 1. Symbol 2. BigInt 3. null vs undefined 四、常见面试扩展问题 五、总结 一、数据类型分类 JavaScript 数据类型分为 基本数据类型&#xff08;原始类型&…...

【进程 】

【进程】 目录1. ELF格式程序与进程2. 进程的组织方式3. 进程的复刻&#xff08;fork&#xff09;4. 进程的状态 目录 1. ELF格式程序与进程 在Linux系统里&#xff0c;程序文件普遍采用ELF&#xff08;Executable and Linkable Format&#xff09;格式。这种格式的程序文件存…...

深入HBase——数据结构与算法

引入 通过前面的文章&#xff0c;我们对HBase已经有了基本认识&#xff0c;下面我们从HBase最核心的算法和数据结构进一步深入HBase。 HBase的一个列簇&#xff08;Column Family&#xff09;本质上就是一棵LSM树&#xff08;Log-Structured Merge-Tree&#xff09;​。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年…...

全链路优化:如何让单点登录认证接口并发性能翻倍?

背景 最近针对一个单点登录认证项目进行性能优化&#xff0c;在 8核 16G 环境下的认证并发能力从每秒800次提升至每秒1600次&#xff0c;性能提升一倍&#xff0c;整理此次优化过程中的相关性能优化操作总结和大家分享一下。 Nginx配置优化 在并发认证场景下&#xff0c;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证书密码&#xff0c;如果需要设置密码&#xff0c;需要再配置给elasticsearch 在之前的步骤中&#xff0c;如果我们对elastic-certificates.p12 文件配置了密码…...

个人简历html网页模板,科技感炫酷html简历模板

炫酷动效登录页 引言 在网页设计中,按钮是用户交互的重要元素之一。这样一款黑色个人简历html网页模板,科技感炫酷html简历模板,设计效果类似科技看板图,可帮您展示技能、任职经历、作品等,喜欢这种风格的小伙伴不要犹豫哦。该素材呈现了数据符号排版显示出人形的动画效…...

在LangFlow中集成OpenAI Compatible API类型的大语言模型

一、背景与核心价值 从Dify换到这个langflow真的时各种的不适应啊。 就比如这个OpenAI Compatible API,这不应该是基本操作嘛? 算了,服了,习惯了就好了。咱闲言少叙,正片开始: LangFlow作为LangChain的可视化开发工具,其最大优势在于无需编写代码即可构建复杂的大模型…...

Qt开发中有关内存管理方面常见的问题分析与解决方案

在Qt开发中&#xff0c;内存管理是一个既基础又关键的一部分知识。尽管Qt提供了自动化的父子对象管理机制&#xff0c;但在复杂的应用场景中&#xff08;如多线程、动态UI、异步操作等&#xff09;&#xff0c;我们在开发过程中&#xff0c;仍可能遇到内存泄漏、野指针、重复释…...

【outOfMemoryError】排查思路与解决方案

前言 不好啦❗ 天塌了❗ 系统崩了❗ 快看啊&#xff0c;程序outOfMemoryError了&#x1f648; 我的心里活动&#xff1a;“哈哈哈&#x1f600;哈哈哈&#x1f600;终于给我碰上了&#xff0c;这个问题可很少发生啊&#xff0c;又积累一个问题。虽然我昨天发了版本&#xff0…...

Python蓝桥杯刷题-小数第n位详解

题目描述 我们知道&#xff0c;整数做除法时&#xff0c;有时得到有限小数&#xff0c;有时得到无限循环小数。 如果我们把有限小数的末尾加上无限多个 0&#xff0c;它们就有了统一的形式。 本题的任务是&#xff1a;在上面的约定下&#xff0c;求整数除法小数点后的第 n 位开…...

Ubuntu服务器 /data 盘需要手动挂载的解决方案

服务器 /data 盘需要手动挂载的解决方案 如果重启服务器后&#xff0c;发现 /data 盘 没有自动挂载&#xff0c;通常是因为&#xff1a; /etc/fstab 配置文件 没有正确设置 自动挂载。该磁盘 没有被正确识别&#xff0c;需要手动挂载。文件系统错误 导致挂载失败。 下面是解…...

无法打开包括文件: “crtdbg.h”: No such file or directory

目录 无效解决措施(重装WindowsSDK) 有效解决措施 创建环境变量 添加环境变量INCLUDE 添加环境变量LIB RC无法运行 问题现象描述 复制以下文件至Error路径 无效解决措施(重装WindowsSDK) 参考文献&#xff1a;94176676/227706449-a5222d7d-d8d2-4a19-addb-8f546e69786f…...

番茄工作法html实现

对比了deepseek-r1-online和本地部署的14b的版本&#xff0c;输出的输出的html页面。 在线满血版的功能比较强大&#xff0c;可以一次完成所有要求。14b版本的功能有一些欠缺&#xff0c;但是基本功能也是写了出来了。 input write a html named Pomodoro-clock which “hel…...

免费开源的WPS AI插件 察元AI助手:getSelectedText 与 resolveDocumentInput 的组合使用

摘要本篇聚焦 documentActions 中选区与全文的衔接。实现新助手时&#xff0c;应明确 sourceMode&#xff0c;并在无选区时是否允许回退全文&#xff0c;以避免误处理整篇公文。关键词选区;全文;sourceMode扩展阅读与维护提示本篇围绕「getSelectedText 与 resolveDocumentInpu…...

STM32寄存器驱动LED流水灯:从仿真到实物的全流程实践

1. 从零开始理解STM32寄存器编程 第一次接触STM32寄存器编程时&#xff0c;我完全被那些十六进制地址和位操作搞懵了。但后来发现&#xff0c;寄存器编程就像直接跟硬件对话&#xff0c;比库函数更接近芯片本质。想象一下&#xff0c;你面前有8个灯泡&#xff08;LED&#xff0…...

60美元AI眼镜TikTok爆卖160万!中国品牌正在改写智能穿戴格局

在跨境电商的世界里&#xff0c;真正的爆款往往不是那些堆砌高端配置的“黑科技”&#xff0c;而是能够用极致性价比让前沿科技走进普通人生活的产品。最近&#xff0c;TikTok美区数码产品榜单上出现了一匹令人瞩目的黑马——一款售价仅60美元左右的AI智能眼镜&#xff0c;在一…...

阿里云国际站 LingduCloud零度云:高额返点,帮企业更省钱地走向全球

这几年&#xff0c;越来越多企业开始把业务往海外铺。可问题也很现实&#xff1a;想做全球化&#xff0c;成本不能太高&#xff0c;部署不能太慢&#xff0c;后续运维还不能太折腾。说白了&#xff0c;大家想要的不是“上云”两个字&#xff0c;而是花更合适的钱&#xff0c;把…...

2026年人工智能专业毕业论文降AI工具推荐:AI技术类论文怎么降AI

2026年人工智能专业毕业论文降AI工具推荐&#xff1a;AI技术类论文怎么降AI 研究生群里聊起AI率的问题&#xff0c;发现十个人里起码六七个都在用工具降。主流的选择其实就那几款&#xff0c;关键是选对了能省很多麻烦。 综合价格和效果&#xff0c;我主推嘎嘎降AI&#xff0…...

【向量搜索落地生死线】:EF Core 10中Embedding缓存穿透、维度错配、FP16截断这3类故障如何10分钟定位?

第一章&#xff1a;EF Core 10向量搜索扩展的架构演进与核心约束EF Core 10 向量搜索扩展并非简单叠加功能&#xff0c;而是对查询管道、模型元数据和提供程序抽象层的一次深度重构。其核心目标是在保持 LINQ 表达式树语义一致性的前提下&#xff0c;将向量相似性计算&#xff…...

从“Hello World”到控制硬件:用汇编语言点亮你的第一个LED灯(基于8086模拟器)

从“Hello World”到控制硬件&#xff1a;用汇编语言点亮你的第一个LED灯&#xff08;基于8086模拟器&#xff09; 当你在屏幕上打印出第一个"Hello World"时&#xff0c;那种成就感可能还停留在抽象的字符层面。但当你用汇编语言直接控制硬件&#xff0c;看到LED灯随…...

阿里通义Z-Image-Turbo WebUI图像生成:快速体验AI绘画的魅力

阿里通义Z-Image-Turbo WebUI图像生成&#xff1a;快速体验AI绘画的魅力 1. 快速入门指南 1.1 一键启动WebUI服务 对于初次接触AI绘画的用户&#xff0c;Z-Image-Turbo WebUI提供了最简单的启动方式。只需在终端执行以下命令&#xff1a; bash scripts/start_app.sh这个脚本…...

从FPGA探索到IC后端:我是如何用OpenROAD开启开源芯片设计之旅的

从FPGA到GDSII&#xff1a;一位工程师的开源芯片设计探索手记 第一次在屏幕上看到自己设计的电路变成硅片上的物理结构时&#xff0c;那种震撼感至今难忘。作为一名长期与FPGA打交道的硬件工程师&#xff0c;我习惯了在可编程逻辑的抽象世界里遨游&#xff0c;直到偶然接触到Op…...

Vivado FIR滤波器实战:从MATLAB仿真到FPGA上板,我的数据截位与时钟方案踩坑记录

Vivado FIR滤波器实战&#xff1a;从MATLAB仿真到FPGA上板的数据截位与时钟方案深度解析 当你在Vivado中完成FIR滤波器的基本设计后&#xff0c;真正的挑战才刚刚开始。作为一位经历过多次项目实战的FPGA开发者&#xff0c;我想分享那些在教科书和官方文档中很少提及的关键细节…...