...args剩余函数用法

https://www.cnblogs.com/hanguidong/p/9449910.html

剩余参数语法允许我们将一个不定数量的参数表示为一个数组。

1

2

3

4

5

6

7

8

9

10

11

function sum(...theArgs) {

  return theArgs.reduce((previous, current) => {

    return previous + current;

  });

}

 

console.log(sum(1, 2, 3));

// expected output: 6

 

console.log(sum(1, 2, 3, 4));

// expected output: 10

语法

1

2

3

function(a, b, ...theArgs) {

  // ...

}

  

描述

如果函数的最后一个命名参数以...为前缀,则它将成为一个数组,其中从0(包括)到theArgs.length(排除)的元素由传递给函数的实际参数提供。

在上面的例子中,theArgs将收集该函数的第三个参数(因为第一个参数被映射到a,而第二个参数映射到b)和所有后续参数。

剩余参数和 arguments对象的区别

剩余参数和 arguments对象之间的区别主要有三个:

  • 剩余参数只包含那些没有对应形参的实参,而 arguments 对象包含了传给函数的所有实参。
  • arguments对象不是一个真正的数组,而剩余参数是真正的 Array实例,也就是说你能够在它上面直接使用所有的数组方法,比如 sortmapforEachpop
  • arguments对象还有一些附加的属性 (如callee属性)。

从 arguments 到数组

引入了剩余参数来减少由参数引起的样板代码。

// Before rest parameters, the following could be found:
function f(a, b) {
  var args = Array.prototype.slice.call(arguments, f.length);

  // …
}

// to be equivalent of

function f(a, b, ...args) {
  
}

解构剩余参数

剩余参数可以被解构,这意味着他们的数据可以被解包到不同的变量中。请参阅解构赋值

1

2

3

4

5

6

7

function f(...[a, b, c]) {

  return a + b + c;

}

 

f(1)          // NaN (b and c are undefined)

f(1, 2, 3)    // 6

f(1, 2, 3, 4) // 6 (the fourth parameter is not destructured)

  

示例

因为theArgs是个数组,所以你可以使用length属性得到剩余参数的个数:

1

2

3

4

5

6

7

function fun1(...theArgs) {

  alert(theArgs.length);

}

  

fun1();  // 弹出 "0", 因为theArgs没有元素

fun1(5); // 弹出 "1", 因为theArgs只有一个元素

fun1(5, 6, 7); // 弹出 "3", 因为theArgs有三个元素

  

下例中,剩余参数包含了从第二个到最后的所有实参,然后用第一个实参依次乘以它们:

1

2

3

4

5

6

7

8

function multiply(multiplier, ...theArgs) {

  return theArgs.map(function (element) {

    return multiplier * element;

  });

}

 

var arr = multiply(2, 1, 2, 3);

console.log(arr);  // [2, 4, 6]

  

下例演示了你可以在剩余参数上使用任意的数组方法,而arguments对象不可以:

1

2

3

4

5

6

7

8

9

10

11

12

13

function sortRestArgs(...theArgs) {

  var sortedArgs = theArgs.sort();

  return sortedArgs;

}

  

alert(sortRestArgs(5,3,7,1)); // 弹出 1,3,5,7

  

function sortArguments() {

  var sortedArgs = arguments.sort();

  return sortedArgs; // 不会执行到这里

}

  

alert(sortArguments(5,3,7,1)); // 抛出TypeError异常:arguments.sort is not a function

  

为了在arguments对象上使用Array方法,它必须首先被转换为一个真正的数组。

1

2

3

4

5

6

function sortArguments() {

  var args = Array.prototype.slice.call(arguments);

  var sortedArgs = args.sort();

  return sortedArgs;

}

console.log(sortArguments(5, 3, 7, 1)); // shows 1, 3, 5, 7

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值