函数的rest参数

  • A+
所属分类:ES 6 JavaScript Web

ES6 引入 rest 参数(形式为...变量名),用于接收可变长度的多个变量。

一.rest参数

1.基本定义

  • ES6 引入 rest 参数(形式为...变量名),用于获取函数的多个参数,替换了arguments对象的使用。
  • rest 参数实际封装为一个数组对象,数组的方法都可以使用。
    function add(...values) {
      let sum = 0;
    
      for (var val of values) {
        sum += val;
      }
    
      return sum;
    }
    
    add(2, 5, 3) // 10
    

2. 使用rest 参数代替arguments变量

  • rest 参数代替arguments变量的例子。
    //arguments对象不是数组,而是一个类似数组的对象。所以为了使用数组的方法,必须使用Array.prototype.slice.call先将其转为数组。rest 参数就不存在这个问题,它就是一个真正的数组,数组特有的方法都可以使用。
    // arguments变量的写法
    function sortNumbers() {
      return Array.prototype.slice.call(arguments).sort();
    }
    
    // rest参数的写法
    const sortNumbers = (...numbers) => numbers.sort();
    

3. rest 参数注意点

  • rest 参数之后不能再有其他参数(即只能是最后一个参数),否则会报错。
    // 报错
    function f(a, ...b, c) {
      // ...
    }
    
  • 函数的length属性,不包括 rest 参数。
    (function(a) {}).length  // 1
    (function(...a) {}).length  // 0
    (function(a, ...b) {}).length  // 1
    
zhangfeng

发表评论

:?: :razz: :sad: :evil: :!: :smile: :oops: :grin: :eek: :shock: :???: :cool: :lol: :mad: :twisted: :roll: :wink: :idea: :arrow: :neutral: :cry: :mrgreen: