ES6擴(kuò)展運(yùn)算符的用途實(shí)例詳解
ES6的擴(kuò)展運(yùn)算符可以說是非常使用的,在給多參數(shù)函數(shù)傳參,替代Apply,合并數(shù)組,和解構(gòu)配合進(jìn)行賦值方面提供了很好的便利性。
擴(kuò)展運(yùn)算符就是三個(gè)點(diǎn)“...”,就是將實(shí)現(xiàn)了Iterator 接口的對(duì)象中的每個(gè)元素都一個(gè)個(gè)的迭代并取出來變成單獨(dú)的被使用。
看這個(gè)例子:
console.log(...[3, 4, 5])
結(jié)果:
3 4 5
調(diào)用其實(shí)就是:
console.log(3, 4, 5)
合并數(shù)組
可以使用擴(kuò)展運(yùn)算符將多個(gè)數(shù)組進(jìn)行合并。
let arr1 = [1, 2, 3] let arr2 = [4, 5, 6] let arr3 = [7, 8, 9] console.log([...arr1, ...arr2, ...arr3])
結(jié)果:
[ 1, 2, 3, 4, 5, 6, 7, 8, 9 ]
函數(shù)多參數(shù)傳遞, 替換Apply
先把參數(shù)定義成數(shù)組,函數(shù)定義好。
let arr4 = ['arg1', 'arg2', 'arg3', 'arg4'] let fun1 = (a1, a2, a3, a4) => { console.log( a1, a2, a3, a4) }
在ES6前,要把數(shù)組參數(shù)傳遞給函數(shù),要么按照下標(biāo)訪問數(shù)組元素去調(diào)用函數(shù),缺點(diǎn)是數(shù)組個(gè)數(shù)和函數(shù)參數(shù)個(gè)數(shù)完全綁定,有一個(gè)個(gè)數(shù)發(fā)生變化,那么就要修改了。
fun1(arr4[0], arr4[1], arr4[2], arr4[3])
要么就用Apply進(jìn)行調(diào)用,結(jié)果當(dāng)然是沒毛病,也是ES6之前用的最多的。
fun1.apply(null, arr4)
如果是用擴(kuò)展運(yùn)算符,那就方便咯。
fun1(...arr4)
結(jié)果:
arg1 arg2 arg3 arg4
調(diào)用簡潔爽快。
與解構(gòu)配合賦值
配合使用,可以從數(shù)組中提取除第一個(gè)以后的所有元素成另外一個(gè)數(shù)組。
let [var1, ...arr5] = [1, 2, 3, 4, 5, 6] console.log(var1) console.log(arr5)
結(jié)果:
1
[ 2, 3, 4, 5, 6 ]
但要注意,與解構(gòu)配合時(shí),擴(kuò)展運(yùn)算符只能用在最后一個(gè)上,否則報(bào)錯(cuò)。
可以展開實(shí)現(xiàn)了Iterator 接口的對(duì)象
比如Map,Set,數(shù)組就是從Iterator接口實(shí)現(xiàn)來的,Object不是,所以擴(kuò)展Object會(huì)報(bào)錯(cuò)。
擴(kuò)展Set。
let set1 = new Set() set1.add(1) set1.add(2) set1.add(3) console.log(...set1)
結(jié)果:
1 2 3
擴(kuò)展Map。
let map1 = new Map(); map1.set('k1', 1); map1.set('k2', 2); map1.set('k3', 3); console.log(...map1)
結(jié)果:
[ 'k1', 1 ] [ 'k2', 2 ] [ 'k3', 3 ]
注意,擴(kuò)展出來的一個(gè)個(gè)的數(shù)組,按照map的鍵值對(duì)結(jié)構(gòu),每個(gè)數(shù)組都是2個(gè)元素,一個(gè)是key,一個(gè)是value。
如果擴(kuò)展Object,就會(huì)報(bào)錯(cuò)。
let obj1 = { p1: 1, p2: 2, p3: 3 } console.log(...obj1)
報(bào)錯(cuò)。
總結(jié)
以上所述是小編給大家介紹的ES6擴(kuò)展運(yùn)算符的用途,希望對(duì)大家有所幫助,如果大家有任何疑問歡迎給我留言,小編會(huì)及時(shí)回復(fù)大家的!
相關(guān)文章
JavaScript實(shí)現(xiàn)一個(gè)空中避難的小游戲
最近利用Javascript實(shí)現(xiàn)了一個(gè)小游戲,覺著還不錯(cuò),所以分享給大家,下面這篇文章主要給大家介紹了利用JavaScript實(shí)現(xiàn)一個(gè)空中避難的小游戲的相關(guān)資料,文中給出了完整的示例代碼供大家參考學(xué)習(xí),需要的朋友們下面來一起看看吧。2017-06-06JS利用cookie記憶當(dāng)前位置的防刷新導(dǎo)航效果
這篇文章主要介紹了JS利用cookie記憶當(dāng)前位置的防刷新導(dǎo)航效果,涉及JavaScript操作cookie及導(dǎo)航樣式布局的相關(guān)技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-10-10ES6 Symbol數(shù)據(jù)類型的應(yīng)用實(shí)例分析
這篇文章主要介紹了ES6 Symbol數(shù)據(jù)類型的應(yīng)用,結(jié)合實(shí)例形式分析了ES6 Symbol數(shù)據(jù)類型的功能、使用方法及相關(guān)操作注意事項(xiàng),需要的朋友可以參考下2019-06-06js 轉(zhuǎn)json格式的字符串為對(duì)象或數(shù)組(前后臺(tái))的方法
下面小編就為大家?guī)硪黄猨s 轉(zhuǎn)json格式的字符串為對(duì)象或數(shù)組(前后臺(tái))的方法。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2016-11-11原生JavaScript實(shí)現(xiàn)Ajax異步請求
ajax現(xiàn)在是一種非常流行的技術(shù),現(xiàn)在雖然可以利用JQuery或者一些第三方插件甚至微軟提供的一些控件可以方面的實(shí)現(xiàn)ajax功能,但是明白其原理也是非常重要的,下面是來使用純javascript實(shí)現(xiàn)獲取服務(wù)器端的功能來展示如何使用純javascript實(shí)現(xiàn)ajax功能,以弄清其原理.2017-11-11JavaScript實(shí)現(xiàn)一個(gè)簡易的計(jì)算器實(shí)例代碼
這篇文章主要介紹了JavaScript實(shí)現(xiàn)一個(gè)簡易的計(jì)算器實(shí)例代碼,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,一起跟隨小編過來看看吧2018-05-05JS/CSS實(shí)現(xiàn)字符串單詞首字母大寫功能
這篇文章主要介紹了JS/CSS實(shí)現(xiàn)字符串單詞首字母大寫功能,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-09-09