ES6函数剩余参数(Rest Parameters)

我们知道JS函数内部有个arguments对象,可以拿到全部实参。现在ES6给我们带来了一个新的对象,可以拿到除开始参数外的参数,即剩余参数(废话好多 O(∩_∩)O~)。

 

这个新的对象和arguments不一样,它是程序员自定义的一个普通标识符,只是需要在前面加上三个点:...

1
2
3
4
5
6
function func(a, ...rest) {
  console.log(a)
  console.log(rest)
}
func(1)
func(1, 2, 3, 4)

注意func的第二个参数rest,前面有三个点。定义好后调用了两次,结果分别如下

可以看到第一次调用时,rest为一个空数组,第二次为[2, 3, 4]。

 

又比如,在前面定义2个参数

1
2
3
4
5
6
function func(a, b, ...rest) {
  console.log(a, b)
  console.log(rest)
}
func(1, 2)
func(1, 2, 3, 4)

输出结果如下

 

通过以上两个示例应该已经了解剩余参数的意义了吧。

 

剩余参数嘛,所以后面就不要再跟其它的参数了,不然会报错

1
2
3
function func(a, ...rest, b) {
 
}

这里在rest后面加了一个参数b,Firefox会报错

 

当您使用剩余参数后,函数的length属性会发生一些变化

1
2
3
function func(a, b, ...rest) {
}
func.length // 2

即length不包含rest,为2。

 

有同学会想,剩余参数前面是否可以一个参数都没有呢? 答案是肯定的

1
2
3
4
5
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一起使用,会报错

1
2
3
4
function func(...rest) {
  console.log(rest)
  console.log(arguments)
}

Firefox控制台如下

 

arguments和剩余参数的区别

  • arguments是一个伪数组(Array-like)
  • 剩余参数是一个真正数组(Array),具有Array.prototype上的所有方法
  • arguments上有callee,callee上有caller

1
2
3
4
function func(a, ...rest) {
    console.log(rest instanceof Array)
}
func(1, 2) // true

 

最后我们以一个剩余参数实际应用作为结束

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
/*
 * 任意个数相加
 *
 * **示例**
 *  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
}

  

相关:

http://www.cnblogs.com/snandy/archive/2011/03/21/1989743.html

posted on   snandy  阅读(17383)  评论(4编辑  收藏  举报

编辑推荐:
· 没有源码,如何修改代码逻辑?
· 一个奇形怪状的面试题:Bean中的CHM要不要加volatile?
· [.NET]调用本地 Deepseek 模型
· 一个费力不讨好的项目,让我损失了近一半的绩效!
· .NET Core 托管堆内存泄露/CPU异常的常见思路
阅读排行:
· DeepSeek “源神”启动!「GitHub 热点速览」
· 微软正式发布.NET 10 Preview 1:开启下一代开发框架新篇章
· C# 集成 DeepSeek 模型实现 AI 私有化(本地部署与 API 调用教程)
· DeepSeek R1 简明指南:架构、训练、本地部署及硬件要求
· NetPad:一个.NET开源、跨平台的C#编辑器
历史上的今天:
2012-05-07 读Ext之十三(Ext元素)
< 2025年2月 >
26 27 28 29 30 31 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 1
2 3 4 5 6 7 8

统计

点击右上角即可分享
微信分享提示