首页 > web前端 > js教程 > 正文

javascript剩余参数是什么_如何收集多个函数参数

夜晨
发布: 2025-12-23 21:50:39
原创
812人浏览过
JavaScript剩余参数(Rest Parameters)用...args语法将多余参数收集为真数组,必须位于参数末尾,支持数组方法且兼容箭头函数;相比arguments更简洁灵活,适用于求和、日志、偏函数等场景。

javascript剩余参数是什么_如何收集多个函数参数

JavaScript剩余参数(Rest Parameters)是一种语法特性,用于将函数中多余的、未命名的参数收集为一个真正的数组。它用三个点 ... 加上一个参数名表示,比如 ...args,必须放在参数列表的最后。

剩余参数的基本写法和特点

剩余参数不是类数组对象,而是标准的 Array 实例,因此可以直接调用 mapfilterreduce 等数组方法。

  • 只能出现在参数列表末尾,且最多只能有一个
  • 即使没有多余参数,剩余参数也会是一个空数组,不会是 undefined
  • 与 arguments 对象不同:arguments 是类数组、非真正数组,且在箭头函数中不可用;剩余参数没有这些限制

和 arguments 的区别为什么推荐用剩余参数)

arguments 是函数内部自动存在的类数组对象,但存在明显局限:

  • 不能直接使用数组方法,需转成数组(如 Array.from(arguments)[...arguments]
  • 箭头函数中没有 arguments 绑定
  • 无法与解构、默认值等现代语法自然配合

而剩余参数天然支持解构、默认值、扩展运算符组合,语义更清晰,代码更简洁。

Studio Global
Studio Global

Studio Global AI 是一个内容生成工具,帮助用户客制化生成风格和内容,以合理价格提供无限生成,希望将 AI 带给全世界所有人。

Studio Global 405
查看详情 Studio Global

立即学习Java免费学习笔记(深入)”;

常见实用场景

剩余参数特别适合处理“参数个数不确定”的函数逻辑:

  • 求和函数function sum(...numbers) { return numbers.reduce((a, b) => a + b, 0); }
  • 日志封装function log(prefix, ...msgs) { console.log(`[${prefix}]`, ...msgs); }
  • 参数预设(偏函数)const add5 = (x, ...rest) => sum(5, x, ...rest);
  • 与解构结合function firstAndRest([first, ...rest]) { return { first, rest }; }

注意事项和易错点

使用时要注意几个细节:

  • 不能和 arguments 混用(虽然语法允许,但会引发混淆,不推荐)
  • 不能在普通函数参数前出现,例如 function f(...rest, last) {} 是语法错误
  • 如果函数只有剩余参数,调用时传不传参都合法:f()args 就是 []
  • 与扩展运算符写法相同(...),但作用相反:剩余参数是“收”,扩展运算是“放”

以上就是javascript剩余参数是什么_如何收集多个函数参数的详细内容,更多请关注php中文网其它相关文章!

java速学教程(入门到精通)
java速学教程(入门到精通)

java怎么学习?java怎么入门?java在哪学?java怎么学才快?不用担心,这里为大家提供了java速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号