zoukankan      html  css  js  c++  java
  • ES6函数扩展-rest参数

    文章参考:https://es6.ruanyifeng.com/#docs/function#rest-参数

    rest参数

    ES6 引入 rest 参数(形式为...变量名),用于获取函数的多余参数,这样就不需要使用arguments对象了。rest 参数搭配的变量是一个数组,该变量将多余的参数放入数组中。

    利用 rest 参数,可以向该函数传入任意数目的参数:求和示例

    function add(...values) {
      let sum = 0;
    
      for (var val of values) {
        sum += val;
      }
    
      return sum;
    }
    // 将所有的参数放入数组中,传递给函数
    add(2, 5, 3) // 输出10
    

    下面是一个rest 参数代替arguments变量的例子。

    // arguments变量的写法
    function sortNumbers() {
      return Array.prototype.slice.call(arguments).sort();
    }
    
    // rest参数的写法
    const sortNumbers = (...numbers) => numbers.sort();
    

    arguments对象不是数组,而是一个类似数组的对象。所以为了使用数组的方法,必须使用Array.prototype.slice.call先将其转为数组。

    rest 参数就不存在这个问题,它就是一个真正的数组,数组特有的方法都可以使用。

    下面是一个利用 rest 参数改写数组push方法的例子。

    function push(array, ...items) {
      items.forEach(function(item) {
        array.push(item);
        console.log(item);
      });
    }
    
    var a = [];
    push(a, 1, 2, 3)
    

    注意,rest 参数之后不能再有其他参数(即只能是最后一个参数),否则会 报错

    // 报错
    function f(a, ...b, c) {
      // ...
    }
    

    函数的length属性,不包括 rest 参数。

    (function(a) {}).length  // 1
    (function(...a) {}).length  // 0
    (function(a, ...b) {}).length  // 1
    

    ------------恢复内容结束------------

  • 相关阅读:
    lodash源码分析之自减的两种形式
    lodash源码分析之NaN不是NaN
    lodash源码分析之Hash缓存
    lodash源码分析之compact中的遍历
    navigate15安装教程
    jmeter线程组调度器使用
    jmeter 注册选择文件编码格式有问题
    jmete插件下载
    jmeter linux 无gui模式分布式压测
    pycharm原码编辑界面快捷键
  • 原文地址:https://www.cnblogs.com/code-duck/p/13413628.html
Copyright © 2011-2022 走看看