es6函数之rest参数用法实例分析


Posted in Javascript onApril 18, 2020

本文实例讲述了es6函数之rest参数用法。分享给大家供大家参考,具体如下:

es6引入rest参数(形式为 …变量名),用于获取函数的多余参数,这样就不需要使用arguments对象了,rest参数搭配的变量是一个数组,该变量将多余的参数放入数组中。

function add (...values) {
 let sum = 0;
 for (var val of values) {
 sum += val
 }
 return sum
}

add(2, 3, 5) // 10

上面代码的add函数是一个求和函数,利用rest参数,可以向该函数传入任意数目的参数。

下面是一个rest参数代替arguments变量的例子。

// arguments变量的写法
function sortNumbers() {
 return Array.prototype.slice.call(arguments).sort()
}

// rest参数的写法
const sortNumbers = (...numbers) => numbers.sort()

上面代码的两种写法,比较后可以发现,rest参数的写法更自然也更简洁。

arguments对象不是数组,而是一个类似数组的对象。所以为了使用数组的方法,必须使用Array.prototype.slice.call先将其转为数组。rest参数就不存在这个问题,它就是一个真正的数组,数组特有的方法都可以使用。下面是一个利用rest参数改写数组push方法的例子。

function push(array, ...items) {
 items.forEach(item => {
 array.push(item)
 })
}

var a = []
push(a, 1, 2, 3)

注意,rest参数之后不能再有其他参数(即只能是最后一个参数),否则会报错

function f (a, ...b, c) {
 // ..
} // 报错

函数的length属性,不包括rest参数。

(function (a) {}).length // 1
(function (...a) {}).length // 0
(function (a, ...b) {}).length // 1

感兴趣的朋友可以使用在线HTML/CSS/JavaScript代码运行工具:http://tools.3water.com/code/HtmlJsRun测试上述代码运行效果。

更多关于JavaScript相关内容可查看本站专题:《JavaScript常用函数技巧汇总》、《javascript面向对象入门教程》、《JavaScript错误与调试技巧总结》、《JavaScript数据结构与算法技巧总结》及《JavaScript数学运算用法总结》

希望本文所述对大家JavaScript程序设计有所帮助。

Javascript 相关文章推荐
Webkit的跨域安全问题说明
Sep 13 Javascript
jQuery学习笔记(3)--用jquery(插件)实现多选项卡功能
Apr 08 Javascript
js中document.write使用过程中的一点疑问解答
Mar 20 Javascript
JS实现从连接中获取youtube的key实例
Jul 02 Javascript
实现非常简单的js双向数据绑定
Nov 06 Javascript
jQuery中show与hide方法用法示例
Sep 16 Javascript
详解使用JS如何制作简单的ASCII图与单极图
Mar 31 Javascript
JavaScript+Canvas实现彩色图片转换成黑白图片的方法分析
Jul 31 Javascript
layui 表格的属性的显示转换方法
Aug 14 Javascript
JS 实现微信扫一扫功能
Sep 14 Javascript
浅谈express.js框架中间件(middleware)
Apr 07 Javascript
浅谈VUE中演示v-for为什么要加key
Jan 16 Javascript
vue实现短信验证码输入框
Apr 17 #Javascript
JS监听组合按键思路及实现过程
Apr 17 #Javascript
javascript canvas检测小球碰撞
Apr 17 #Javascript
Vue实现浏览器打印功能的代码
Apr 17 #Javascript
基于JavaScript获取url参数2种方法
Apr 17 #Javascript
VSCode写vue项目一键生成.vue模版,修改定义其他模板的方法
Apr 17 #Javascript
vue fetch中的.then()的正确使用方法
Apr 17 #Javascript
You might like
解析dedeCMS验证码的实现代码
2013/06/07 PHP
php打造智能化的柱状图程序,用于报表等
2015/06/19 PHP
为何说PHP引用是个坑,要慎用
2018/04/02 PHP
python进程与线程小结实例分析
2018/11/11 PHP
PHP实现支持CURL字符串证书传输的方法
2019/03/23 PHP
图片自动更新(说明)
2006/10/02 Javascript
jQuery 获取浏览器所在的IP地址的小例子
2013/11/08 Javascript
jQuery ui 利用 datepicker插件实现开始日期(minDate)和结束日期(maxDate)
2014/05/22 Javascript
使用jQuery实现验证上传图片的格式与大小
2014/12/03 Javascript
超详细的JS弹出窗口代码大全
2020/04/18 Javascript
js实现图片切换(动画版)
2016/12/25 Javascript
js数组去重的N种方法(小结)
2018/06/07 Javascript
JS中的继承操作实例总结
2020/06/06 Javascript
python计算程序开始到程序结束的运行时间和程序运行的CPU时间
2013/11/28 Python
利用Python学习RabbitMQ消息队列
2015/11/30 Python
利用python模拟实现POST请求提交图片的方法
2017/07/25 Python
Ubuntu下Python2与Python3的共存问题
2018/10/31 Python
配置 Pycharm 默认 Test runner 的图文教程
2018/11/30 Python
使用python搭建服务器并实现Android端与之通信的方法
2019/06/28 Python
Python进程间通信 multiProcessing Queue队列实现详解
2019/09/23 Python
pyspark给dataframe增加新的一列的实现示例
2020/04/24 Python
PyInstaller的安装和使用的详细步骤
2020/06/02 Python
小女主人连衣裙:Little Mistress
2017/07/10 全球购物
英国电子专家:maplin
2019/09/04 全球购物
老师推荐信
2013/10/28 职场文书
优秀应届生推荐信
2013/11/09 职场文书
财务副总经理工作职责
2013/11/25 职场文书
青春寄语大全
2014/04/09 职场文书
ktv周年庆活动方案
2014/08/18 职场文书
2014年财务工作总结范文
2014/11/11 职场文书
教师工作态度自我评价
2015/03/05 职场文书
社区义诊通知
2015/04/24 职场文书
学习雷锋精神倡议书
2015/04/27 职场文书
导游词之台湾安平古堡
2019/12/25 职场文书
Python趣味实战之手把手教你实现举牌小人生成器
2021/06/07 Python
Typescript类型系统FLOW静态检查基本规范
2022/05/25 Javascript