ES6函数剩余参数(Rest Parameters)
2015-05-07 08:11
190 查看
我们知道JS函数内部有个arguments对象,可以拿到全部实参。现在ES6给我们带来了一个新的对象,可以拿到除开始参数外的参数,即剩余参数(废话好多 O(∩_∩)O~)。
这个新的对象和arguments不一样,它是程序员自定义的一个普通标识符,只是需要在前面加上三个点:...
注意func的第二个参数rest,前面有三个点。定义好后调用了两次,结果分别如下
可以看到第一次调用时,rest为一个空数组,第二次为[2, 3, 4]。
又比如,在前面定义2个参数
输出结果如下
通过以上两个示例应该已经了解剩余参数的意义了吧。
剩余参数嘛,所以后面就不要再跟其它的参数了,不然会报错
这里在rest后面加了一个参数b,Firefox会报错
当您使用剩余参数后,函数的length属性会发生一些变化
即length不包含rest,为2。
有同学会想,剩余参数前面是否可以一个参数都没有呢? 答案是肯定的
这里的rest实际和arguments功能差不多,有同学想这不就替代了arguments吗? ECMAScript就是这个打算,在被废弃的ES4里就已经有Rest Parameters(熟悉AS3的同学应该了解),ES4被废弃后,Rest Parameters被保留到了ES6。
请注意,rest不能和arguments一起使用,会报错
Firefox控制台如下
arguments和剩余参数的区别
arguments是一个伪数组(Array-like)
剩余参数是一个真正数组(Array),具有Array.prototype上的所有方法
arguments上有callee,callee上有caller
如
最后我们以一个剩余参数实际应用作为结束
相关:
/article/4664215.html
这个新的对象和arguments不一样,它是程序员自定义的一个普通标识符,只是需要在前面加上三个点:...
function func(a, ...rest) { console.log(a) console.log(rest) } func(1) func(1, 2, 3, 4)
注意func的第二个参数rest,前面有三个点。定义好后调用了两次,结果分别如下
可以看到第一次调用时,rest为一个空数组,第二次为[2, 3, 4]。
又比如,在前面定义2个参数
function func(a, b, ...rest) { console.log(a, b) console.log(rest) } func(1, 2) func(1, 2, 3, 4)
输出结果如下
通过以上两个示例应该已经了解剩余参数的意义了吧。
剩余参数嘛,所以后面就不要再跟其它的参数了,不然会报错
function func(a, ...rest, b) { }
这里在rest后面加了一个参数b,Firefox会报错
当您使用剩余参数后,函数的length属性会发生一些变化
function func(a, b, ...rest) { } func.length // 2
即length不包含rest,为2。
有同学会想,剩余参数前面是否可以一个参数都没有呢? 答案是肯定的
function func(...rest) { console.log(rest) } func(1) // [1] func(1, 2, 3, 4) // [1,2,3,4]
这里的rest实际和arguments功能差不多,有同学想这不就替代了arguments吗? ECMAScript就是这个打算,在被废弃的ES4里就已经有Rest Parameters(熟悉AS3的同学应该了解),ES4被废弃后,Rest Parameters被保留到了ES6。
请注意,rest不能和arguments一起使用,会报错
function func(...rest) { console.log(rest) console.log(arguments) }
Firefox控制台如下
arguments和剩余参数的区别
arguments是一个伪数组(Array-like)
剩余参数是一个真正数组(Array),具有Array.prototype上的所有方法
arguments上有callee,callee上有caller
如
function func(a, ...rest) { console.log(rest instanceof Array) } func(1, 2) // true
最后我们以一个剩余参数实际应用作为结束
/* * 任意个数相加 * * **示例** * sum(1) * sum(1, 2) * sum(1, 2, 3) */ function sum(first, ...rest) { var result = first var i = 0 var len = rest.length while (i < len) { result += rest[i] i++ } return result }
相关:
/article/4664215.html
相关文章推荐
- ECMAScript6函数剩余参数(Rest Parameters)
- ECMAScript6函数剩余参数(Rest Parameters)
- 理解es6---第二章 函数(箭头函数,spread parameters, rest parameters, 匿名参数)
- JavaScript—函数参数:默认参数和剩余参数
- es6剩余参数
- ES6-函数的参数
- ES6-函数的扩展-函数参数的默认值
- ECMAScript6(ES6)标准之函数扩展特性箭头函数、Rest参数及展开操作符
- 11、ES6 函数参数的解构赋值
- JavaScript:实例讲解使用ES6中默认参数和剩余参数时的注意事项
- ES6——剩余参数
- ES6学习总结之函数变化(函数默认参数,扩展运算符,箭头函数)
- ES6之函数参数表达、传参
- Lisp语言:函数的可选参数,剩余参数以及关键字参数
- ES6 随记(3.4.1)-- 函数的拓展(参数默认值,扩展运算符)
- ES6-函数的扩展-rest参数
- ES6-函数的扩展-catch语句的参数
- ES6 函数参数默认值 default
- ES6学习——新的语法:函数参数Spread
- [js高手之路] es6系列教程 - 函数的默认参数详解