zoukankan      html  css  js  c++  java
  • ES6----拓展运算符 三个点【...】

    【...】拓展运算符是什么?

    es6中引入扩展运算符(...),它用于把一个数组转化为用逗号分隔的参数序列,它常用在不定参数个数时的函数调用,数组合并等情形。因为typeScript是es6的超集,所以typeScript也支持扩展运算符。

    【...】用在什么地方?

    1、可变参数个数的函数调用

    function push(array, ...items) {  
      array.push(...items);  
    }  
    
    function add(...vals){
      let sum=0;
      for(let i=0;i<vals.length;i++){
        sum+=vals[i];
      }
      return sum;
    }
    
    let arr = [1,2,3,4,5,6];
    let sum = add(...arr);
    console.log(sum);  //21

    2、更便捷的数组合并

    let arr1 = [1,2];
    let arr2 = [5,6];
    let newArr = [20];
    //es5 旧写法
    newArr = newArr.concat(arr1).concat(arr2); //[20,1,2,5,6]
    console.log(newArr);
    //es6 使用扩展运算符
    newArr = [20,...arr1,...arr2];  //[20,1,2,5,6]
    console.log(newArr);

    3、替代es5的apply方法

    // ES5 的写法  
    function f(x, y, z) {  
    // ...  
    }  
    var args = [0, 1, 2];  
    f.apply(null, args);  
    // ES6 的写法  
    function f(x, y, z) {  
    // ...  
    }  
    var args = [0, 1, 2];  
    f(...args);  

    4、求最大值Math.max()

    // ES5 的写法  
    Math.max.apply(null, [14, 3, 77])  
    // ES6 的写法  
    Math.max(...[14, 3, 77])  
    //  等同于  
    Math.max(14, 3, 77);  

    通过push函数,将一个数组添加到另一个数组的尾部

    // ES5 的写法  
    var arr1 = [0, 1, 2];  
    var arr2 = [3, 4, 5];  
    Array.prototype.push.apply(arr1, arr2);  
    // ES6 的写法  
    var arr1 = [0, 1, 2];  
    var arr2 = [3, 4, 5];  
    arr1.push(...arr2);  

    新建Date类型

    // ES5  
    new (Date.bind.apply(Date, [null, 2015, 1, 1]))  
    // ES6  
    new Date(...[2015, 1, 1]);  

    与解构赋值结合,生成新数组

    // ES5  
    a = list[0], rest = list.slice(1)  
    // ES6  
    [a, ...rest] = list 
    下面是另外一些例子。  
    const [first, ...rest] = [1, 2, 3, 4, 5];  
    first // 1  
    rest // [2, 3, 4, 5]  
    const [first, ...rest] = [];  
    first // undefined  
    rest // []:  
    const [first, ...rest] = ["foo"];  
    first // "foo"  
    rest // [] 

    将字符串转为真正的数组

    [...'hello']  
    // [ "h", "e", "l", "l", "o" ]  

    将实现了 Iterator 接口的对象转为数组

    var nodeList = document.querySelectorAll('div');  
    var array = [...nodeList];  
  • 相关阅读:
    javascript设计模式——链式模式学习
    浏览器debug常用技巧
    前端到底要不要学后台
    坑爹的JS闭包,怎么去理解才是正确的
    如何更加简单的理解JS中的原型原型链概念
    前端那么多框架,我们到底学哪一个
    大前端之——数据交互
    随便写一点自己对前端的感受
    如何手动使用webpack搭建一个react项目
    浅谈 CSS 预处理器: 为什么要使用预处理器?
  • 原文地址:https://www.cnblogs.com/e0yu/p/11276714.html
Copyright © 2011-2022 走看看