ES6睁开运算符

语法

  • 用于函数挪用

    myFunction(...iterableObj);
  • 用于数组字面量

    [...iterableObj, 4, 5, 6]

函数传参

目前为止,我们都是运用Function.prototype.apply方法来将一个数组睁开成多个参数:

function myFunction(x, y, z) { }
var args = [0, 1, 2];
myFunction.apply(null, args);

运用es6的睁开运算符能够这么写:

function myFunction(x, y, z) { }
var args = [0, 1, 2];
myFunction(...args);
  • 选择性传参

    function filter(type, ...items) {
        return items.filter(item => typeof item === type);
    }
    filter('boolean', true, 0, false);        // => [true, false]
    filter('number', false, 4, 'Welcome', 7); // => [4, 7]

还能够同时睁开多个数组:

function myFunction(v, w, x, y, z) { }
var args = [0, 1];
myFunction(-1, ...args, 2, ...[3]);

数据解构

let cold = ['autumn', 'winter'];
let warm = ['spring', 'summer'];
// 析构数组
let otherSeasons, autumn;
[autumn, ...otherSeasons] = cold;
otherSeasons      // => ['winter']

数据组织

  • 两个对象衔接返回新的对象

    let a = {aa:'aa'}
    let b = {bb:'bb'}
    let c = {...a,...b}
    console.log(c)
    // {"aa":"aa","bb":"bb"}
  • 两个数组衔接返回新的数组

    let d = ['dd']
    let e = ['ee']
    let f = [...d,...e]
    console.log(f)
    // ["dd","ee"]
    • 在中心插进去数组

      var parts = ['shoulder', 'knees'];
      var lyrics = ['head', ...parts, 'and', 'toes']; // ["head", "shoulders", "knees", "and", "toes"]
    • 在尾部插进去数组

      // ES5
      var arr1 = [0, 1, 2];
      var arr2 = [3, 4, 5];
      // 将arr2中的一切元素添加到arr1中
      Array.prototype.push.apply(arr1, arr2);
      
      // ES6
      var arr1 = [0, 1, 2];
      var arr2 = [3, 4, 5];
      arr1.push(...arr2);
  • 数组加上对象返回新的数组

    let g = [{gg:'gg'}]
    let h = {hh:'hh'}
    let i = [...g,h]
    console.log(i)
    // [{"gg":"gg"},{"hh":"hh"}
  • 数组+字符串

    let j = ['jj']
    let k = 'kk'
    let l = [...j,k]
    console.log(l)
    // ["jj","kk"]
  • 带有数组和对象的连系

    let state = {
        resultList: [],
        currentPage: 0,
        totalRows: {}
    }
    let data = {
        resultList: [{new:'new'}],
        currentPage: 2,
        totalRows: {row:'row'}
    }
    let combile = {
                    ...state,
                    resultList: [
                        ...state.resultList,
                        ...data.resultList
                    ],
                    currentPage: data.currentPage,
                    totalRows: data.totalRows
                }
    console.log(combile)
    // {"resultList":[{"new":"new"}],"currentPage":2,"totalRows":{"row":"row"}}
    原文作者:影绰
    原文地址: https://segmentfault.com/a/1190000007022442
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
点赞