ES6的扩展运算符和剩余操作符的对比和应用

扩展运算符

扩展运算符写法是三个点...,写法虽然跟剩余操作符一致,都是...,但是作用可以认为是相反的。

扩展运算符的核心就是2个字:打散。

剩余操作符的核心就是2个字:打包。

剩余操作符和扩展运算符在赋值方面的对比:

剩余操作符是:表示剩下的打包,通常是只可能放在变量名前面;一定有赋值或者传值操作:

let [a, ...b] = [1,2,3,4,5];
b; // [2,3,4,5]

扩展运算符是:表示把打包好的打散,可能放在变量名前面,也可能放在的前面;可能有赋值操作,也可能没有赋值操作:

let a = [1, ...[2,3,4]]; // 注意,既然是先打散然后赋值给一个变量,就需要用[]包起来形成数组
a; // [1, 2, 3, 4]
console.log(1, ...[2,3,4]); // 1, 2, 3, 4

剩余操作符跟扩展运算符的在函数方面的应用对比:

请仔细对比下面两个例子。

  1. 剩余操作符举例:
function ff (...a) {
    return a[0] + '-' + a[1] + '-' + a[2];
}

ff(1,3,5); // '1-3-5'
  1. 扩展运算符举例:
function ff (a,b,c) {
    return a + '-' + b + '-' + c;
}

let x = [1,3,5];

ff(...x); // '1-3-5'

扩展运算符可以跟表达式,将表达式的运算结果打散。

console.log(...('abcd'.split(''))); // a, b, c, d

本质理解

其实ES6之所以把这两个关键字设成一致的写法,是因为它们本质是一样,都是解构赋值。

我们复习一下解构赋值,下面用的是剩余操作符:

let [a, b, ...c] = [1,2,3,4,5];

JS引擎会拿元素依次为变量赋值,到c变量的时候,会一次性的把[3,4,5]赋值给c,虽然直观的感受是c变量打包了3个元素,但是其实等于是...把c打散成了3个变量位置,然后一对一赋值,最后再合成一个数组。

再看运用扩展运算符的解构赋值:

let [a, b, c] = [...[1,2,3]];
c; // 3

其实...也是先打散数组,然后再一对一赋值。

最后看一个朴素的解构赋值的栗子:

let [...a] = [...[1,2,3]]; // 右边打散成元素,左边又给打包起来
a; // [1, 2, 3]

// 忽略掉外面的数组括号,忽略掉三个点,就相当于:
let a = [1,2,3];

扩展运算符的应用(核心就是打散)

一、把数组打散成多个参数

经常看js奇技淫巧的同学,应该知道把数组打散成多个参数,有一个方法是用apply方法,比如,找出数组里的最大的数:

Math.max.apply(null, [14, 3, 77]); // 77

这种写法利用的apply的特性:foo.apply(this,arguments)==this.foo(arg1, arg2, arg3),由于apply方法比较难理解,一般使用者也比较抵触用这个方法,所以应用不多,现在好了,有了扩展运算符,ES算是给了一个官方的打散数组为参数的方法。

Math.max(...[14, 3, 77])

二、一次性合并多个数组

ES5确实已经有很好的合并方法.concat,所以扩展运算符只是提供了另一条路,ES6这个扩展运算符写法的好处是不借助函数,只是JS运算。

// ES5
[1, 2].concat(more)
// ES6
[1, 2, ...more] // ...会把more打散
var arr1 = ['a', 'b'];
var arr2 = ['c'];
var arr3 = ['d', 'e'];

// ES5的合并数组
arr1.concat(arr2, arr3);
// [ 'a', 'b', 'c', 'd', 'e' ]

// ES6的合并数组
[...arr1, ...arr2, ...arr3]
// [ 'a', 'b', 'c', 'd', 'e' ]

三、复制数组

由于数组赋值是传址而不是传值,所以ES5复制数组的方法是这样:

const a1 = [1, 2];
const a2 = a1.concat(); // concat会生成新的数组

现在ES6可以这么写:

const a1 = [1, 2];
// 写法一,利用扩展运算符
const a2 = [...a1];
// 写法二,利用剩余操作符
const [...a2] = a1;

四、将字符串打散为数组

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

五、打散实现了 Iterator 接口的对象

实现了 Iterator 接口的对象比如document.querySelectorAll('div')

let nodeList = document.querySelectorAll('div'); // nodeList对象不是数组,而是一个类似数组的对象
let array = [...nodeList]; // 真正的数组

六、打散Map和Set结构

let map = new Map([
  [1, 'one'],
  [2, 'two'],
  [3, 'three'],
]);

let arr = [...map.keys()]; // [1, 2, 3]

七、打散迭代器对象

const go = function*(){
  yield 1;
  yield 2;
  yield 3;
};

[...go()] // [1, 2, 3]

剩余操作符的应用(核心就是打包)

一、解构再打包赋值

这是剩余操作符的最基本用法,本文最开始就说过,不再说。

二、函数打包传参

上面也提过,不再说。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 206,214评论 6 481
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 88,307评论 2 382
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 152,543评论 0 341
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 55,221评论 1 279
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 64,224评论 5 371
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,007评论 1 284
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,313评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,956评论 0 259
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 43,441评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,925评论 2 323
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,018评论 1 333
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,685评论 4 322
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,234评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,240评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,464评论 1 261
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,467评论 2 352
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,762评论 2 345