JavaScript剩余参数详解教程
时间:2025-11-25 15:49:52 400浏览 收藏
欢迎各位小伙伴来到golang学习网,相聚于此都是缘哈哈哈!今天我给大家带来《JavaScript 剩余参数使用教程》,这篇文章主要讲到等等知识,如果你对文章相关的知识非常感兴趣或者正在自学,都可以关注我,我会持续更新相关文章!当然,有什么建议也欢迎在评论留言提出!一起学习!
剩余参数是JavaScript中用于收集函数多余参数的数组,语法为...parameterName,必须位于参数末尾,可直接调用数组方法,区别于非数组的arguments对象,且支持与固定参数共存,提升代码可读性与安全性。

JavaScript 中的剩余参数(Rest Parameters)提供了一种简洁的方式处理函数中不确定数量的参数。通过使用三个点 (...) 加上一个形参名,可以把调用时传入的多个实参收集为一个数组,便于后续操作。
什么是剩余参数
剩余参数语法允许我们将一个不定数量的参数表示为一个数组。它出现在函数定义的最后一个参数前,格式为 ...parameterName。
例如:
function sum(...numbers) {return numbers.reduce((total, num) => total + num, 0);
}
sum(1, 2, 3); // 返回 6
sum(4, 5); // 返回 9
sum(); // 返回 0
在这个例子中,...numbers 将所有传入的参数收集为一个数组,然后使用 reduce() 方法计算总和。
与 arguments 对象的区别
在剩余参数出现之前,开发者通常使用函数内部的 arguments 对象来访问所有参数。但 arguments 不是真正的数组,不能直接调用如 map、filter 等数组方法。
剩余参数的优势在于:
- 它是真正的数组,可以直接使用数组方法
- 语法更清晰,意图更明确
- 可以和其他形参共存,只收集未命名的参数
示例对比:
// 使用 argumentsfunction concatWithArgs() {
return Array.prototype.slice.call(arguments).join(' ');
}
// 使用剩余参数
function concat(...parts) {
return parts.join(' ');
}
结合其他参数使用
剩余参数必须是函数的最后一个参数,前面可以有其他固定参数。
比如,你想让第一个参数作为分隔符,后面的是要连接的内容:
function joinStrings(separator, ...words) {return words.join(separator);
}
joinStrings('-', 'a', 'b', 'c'); // 返回 'a-b-c'
joinStrings(' ', 'Hello', 'world'); // 返回 'Hello world'
这里 separator 接收第一个参数,其余的都被 ...words 收集。
注意事项
使用剩余参数时需要注意以下几点:
- 每个函数只能有一个剩余参数,且必须位于参数列表末尾
- 剩余参数不能出现在解构或默认值之后
- 箭头函数也支持剩余参数
错误示例:
// 错误:剩余参数不在最后function badFunc(...rest, last) { } // SyntaxError
// 错误:两个剩余参数
function anotherBad(...a, ...b) { } // SyntaxError
基本上就这些。剩余参数让处理可变参数变得更直观、更安全,推荐在需要接收任意数量参数时优先使用。不复杂但容易忽略细节。
以上就是本文的全部内容了,是否有顺利帮助你解决问题?若是能给你带来学习上的帮助,请大家多多支持golang学习网!更多关于文章的相关知识,也可关注golang学习网公众号。
-
502 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
474 收藏
-
352 收藏
-
243 收藏
-
337 收藏
-
419 收藏
-
340 收藏
-
183 收藏
-
350 收藏
-
105 收藏
-
205 收藏
-
369 收藏
-
176 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 516次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 500次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 485次学习