ES6中rest参数详细讲解
标签:
JavaScript
(1) Rest 参数接受函数的多余参数,组成一个数组,放在形参的最后,形式如下:
function func(a, b, ...theArgs){ // ...}
(2) Rest参数和arguments对象的区别:
rest参数只包括那些没有给出名称的参数,arguments包含所有参数
arguments 对象不是真正的数组,而rest 参数是数组实例,可以直接应用sort, map, forEach, pop等方法
arguments 对象拥有一些自己额外的功能
(3) 从 arguments 转向数组
Rest 参数简化了使用 arguments 获取多余参数的方法
// arguments 方法function func(a, b){ var args = Array.prototype.slice.call(arguments); console.log(args) } func(1,2)// Rest 方法function func(a, b, ...args){ // ...}
注意,rest 参数之后不能再有其他参数(即,只能是最后一个参数),否则会报错
function func(a, ...b, c) { // ...}// Rest parameter must be last formal parameter
函数的 length 属性,不包括rest参数
(function(a) {}).length // 1(function(...a) {}).length // 0(function(a, b, ...c)).length // 2
(4) Rest参数可以被结构(通俗一点,将rest参数的数据解析后一一对应)不要忘记参数用[]括起来,因为它是数组
function f(...[a, b, c]) { return a + b + c; } f(1) //NaN 因为只传递一个值,其实需要三个值 f(1, 2, 3) // 6 f(1, 2, 3, 4) // 6 (第四值没有与之对应的变量名)
转载:https://www.jianshu.com/p/50bcb376a419
点击查看更多内容
为 TA 点赞
评论
共同学习,写下你的评论
评论加载中...
作者其他优质文章
正在加载中
感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦