javascript剩余参数_怎样处理不定数量参数
发布时间 - 2026-01-08 00:00:00 点击率:次剩余参数(...)是ES6引入的语法,用于捕获函数末尾不定数量参数并形成真数组;而arguments是类数组对象,无数组方法且箭头函数中不可用。
什么是 ... 剩余参数,和 arguments 有什么区别
剩余参数(Rest Parameters)用 ... 语法捕获函数末尾的不定数量参数,它是个真正的数组;而 arguments 是类数组对象,没有 map、filter 等方法,也不能直接解构。
常见错误是把 arguments 当成数组来用,比如写 arguments.map(...),会报 TypeError: arguments.map is not a function。
-
...只能出现在形参列表**最后**,且只能有一个 -
arguments在箭头函数中不可用,剩余参数可以 - 剩余参数自动绑定为数组,可直接用
reduce、forEach、扩展运算符等
怎么正确声明和使用 ... 剩余参数
声明时必须带名字,比如 ...items,不能单独写 ...。它会收集从第一个未匹配形参开始的所有实参。
function sum(...numbers) {
return numbers.reduce((a, b) => a + b, 0);
}
sum(1, 2, 3); // 6
sum(); // 0(空数组 reduce 得 0)
- 如果前面还有固定参数,剩余参数只收“多出来的”部分:
function fn(a, b, ...rest)中传fn(1, 2, 3, 4)→a=1,b=2,rest=[3,4] - 剩余参数不能和同名变量冲突,比如不能写
function f(...args) { const args = [] }(会报Identifier 'args' has already been declared) - 它不包含默认参数的值,只反映实际传入的参数个数
剩余参数 vs 扩展运算符:别混淆 ... 的两种用法
同一个 ... 符号,在函数定义里是剩余参数(收集),在函数调用或字面量里是扩展运算符(展开)。容易在嵌套调用时搞反方向。
function log(...msgs) {
console.log('start:', ...msgs); // 这里是扩展:把 msgs 数组展开成多个参数
}
log('a', 'b'); // start: a b
- 定义函数时
...在左边 → 收集参数(剩余参数) - 调用函数或构造数组/对象时
...在右边 → 展开可迭代对象(扩展运算符) - 常见错误:试图在对象解构中用
...rest收集剩余属性而不加{}包裹,那是无效语法
兼容性与替代方案:什么时候不能用 ...
IE 完全不支持剩余参数,Node.js 4+ 和现代浏览器都支持。如果需兼容旧环境,得用 Array.prototype.slice.call(arguments) 模拟。
// 不推荐的兼容写法(仅当真要支持 IE 时才考虑)
function oldStyle() {
var args = Array.prototype.slice.call(arguments, 1); // 跳过第一个参数
ret
urn args.join('-');
}
- Babel 默认会把剩余参数转为
slice调用,但要注意arguments在严格模式下对caller/callee的限制 - TypeScript 中剩余参数类型需显式标注,如
...ids: number[],否则推导为any[] - 不要在递归函数中无节制地展开大数组,可能触发栈溢出或内存问题
undefined 或 null —— 它们照单全收。传 fn(1, undefined, 3),... 拿到的就是 [1, undefined, 3],不是 [1, 3]。
# javascript
# es6
# java
# js
# node.js
# node
# typescript
# 浏览器
# 栈
# 递归函数
# 区别
相关栏目:
【
网站优化151355 】
【
网络推广146373 】
【
网络技术251813 】
【
AI营销90571 】
相关推荐:
Laravel如何实现数据库事务?(DB Facade示例)
Laravel如何升级到最新的版本_Laravel版本升级流程与兼容性处理
HTML5段落标签p和br怎么选_文本排版常用标签对比【解答】
个人网站制作流程图片大全,个人网站如何注销?
北京的网站制作公司有哪些,哪个视频网站最好?
简单实现jsp分页
Windows10如何更改计算机工作组_Win10系统属性修改Workgroup
JavaScript如何实现类型判断_typeof和instanceof有什么区别
如何用5美元大硬盘VPS安全高效搭建个人网站?
广州网站制作公司哪家好一点,广州欧莱雅百库网络科技有限公司官网?
logo在线制作免费网站在线制作好吗,DW网页制作时,如何在网页标题前加上logo?
深圳网站制作平台,深圳市做网站好的公司有哪些?
香港服务器选型指南:免备案配置与高效建站方案解析
WEB开发之注册页面验证码倒计时代码的实现
Laravel的契約(Contracts)是什么_深入理解Laravel Contracts与依赖倒置
如何在阿里云完成域名注册与建站?
JavaScript Ajax实现异步通信
Midjourney怎样加参数调细节_Midjourney参数调整技巧【指南】
ai格式如何转html_将AI设计稿转换为HTML页面流程【页面】
Laravel如何获取当前用户信息_Laravel Auth门面获取用户ID
如何实现javascript表单验证_正则表达式有哪些实用技巧
Laravel怎么配置S3云存储驱动_Laravel集成阿里云OSS或AWS S3存储桶【教程】
如何在建站之星网店版论坛获取技术支持?
HTML5建模怎么导出为FBX格式_FBX格式兼容性及导出步骤【指南】
Laravel模型事件有哪些_Laravel Model Event生命周期详解
香港服务器部署网站为何提示未备案?
如何快速查询网址的建站时间与历史轨迹?
Laravel API资源(Resource)怎么用_格式化Laravel API响应的最佳实践
Laravel Telescope怎么调试_使用Laravel Telescope进行应用监控与调试
最好的网站制作公司,网购哪个网站口碑最好,推荐几个?谢谢?
如何在搬瓦工VPS快速搭建网站?
如何快速生成ASP一键建站模板并优化安全性?
Laravel事件和监听器如何实现_Laravel Events & Listeners解耦应用的实战教程
网站设计制作书签怎么做,怎样将网页添加到书签/主页书签/桌面?
打造顶配客厅影院,这份100寸电视推荐名单请查收
Laravel如何实现登录错误次数限制_Laravel自带LoginThrottles限流配置【方法】
详解Android——蓝牙技术 带你实现终端间数据传输
Laravel定时任务怎么设置_Laravel Crontab调度器配置
米侠浏览器网页背景异常怎么办 米侠显示修复
如何在阿里云ECS服务器部署织梦CMS网站?
如何快速上传自定义模板至建站之星?
Laravel如何将应用部署到生产服务器_Laravel生产环境部署流程
大学网站设计制作软件有哪些,如何将网站制作成自己app?
Laravel如何使用Service Provider注册服务_Laravel服务提供者配置与加载
Windows10电脑怎么设置虚拟光驱_Win10右键装载ISO镜像文件
php 三元运算符实例详细介绍
Android使用GridView实现日历的简单功能
Android GridView 滑动条设置一直显示状态(推荐)
阿里云高弹*务器配置方案|支持分布式架构与多节点部署
如何快速搭建支持数据库操作的智能建站平台?


urn args.join('-');
}