您好,登錄后才能下訂單哦!
這篇文章給大家介紹ES6擴展運算符的使用場景有哪些,內容非常詳細,感興趣的小伙伴們可以參考借鑒,希望對大家能有所幫助。
ES6的擴展運算符可以說是非常使用的,在給多參數函數傳參,替代Apply,合并數組,和解構配合進行賦值方面提供了很好的便利性。
擴展運算符就是三個點“...”,就是將實現了Iterator 接口的對象中的每個元素都一個個的迭代并取出來變成單獨的被使用。
看這個例子:
console.log(...[3, 4, 5])
結果:
3 4 5
調用其實就是:
console.log(3, 4, 5)
合并數組
可以使用擴展運算符將多個數組進行合并。
let arr1 = [1, 2, 3] let arr2 = [4, 5, 6] let arr3 = [7, 8, 9] console.log([...arr1, ...arr2, ...arr3])
結果:
[ 1, 2, 3, 4, 5, 6, 7, 8, 9 ]
函數多參數傳遞, 替換Apply
先把參數定義成數組,函數定義好。
let arr4 = ['arg1', 'arg2', 'arg3', 'arg4'] let fun1 = (a1, a2, a3, a4) => { console.log( a1, a2, a3, a4) }
在ES6前,要把數組參數傳遞給函數,要么按照下標訪問數組元素去調用函數,缺點是數組個數和函數參數個數完全綁定,有一個個數發生變化,那么就要修改了。
fun1(arr4[0], arr4[1], arr4[2], arr4[3])
要么就用Apply進行調用,結果當然是沒毛病,也是ES6之前用的最多的。
fun1.apply(null, arr4)
如果是用擴展運算符,那就方便咯。
fun1(...arr4)
結果:
arg1 arg2 arg3 arg4
調用簡潔爽快。
與解構配合賦值
配合使用,可以從數組中提取除第一個以后的所有元素成另外一個數組。
let [var1, ...arr5] = [1, 2, 3, 4, 5, 6] console.log(var1) console.log(arr5)
結果:
1
[ 2, 3, 4, 5, 6 ]
但要注意,與解構配合時,擴展運算符只能用在最后一個上,否則報錯。
可以展開實現了Iterator 接口的對象
比如Map,Set,數組就是從Iterator接口實現來的,Object不是,所以擴展Object會報錯。
擴展Set。
let set1 = new Set() set1.add(1) set1.add(2) set1.add(3) console.log(...set1)
結果:
1 2 3
擴展Map。
let map1 = new Map(); map1.set('k1', 1); map1.set('k2', 2); map1.set('k3', 3); console.log(...map1)
結果:
[ 'k1', 1 ] [ 'k2', 2 ] [ 'k3', 3 ]
注意,擴展出來的一個個的數組,按照map的鍵值對結構,每個數組都是2個元素,一個是key,一個是value。
如果擴展Object,就會報錯。
let obj1 = { p1: 1, p2: 2, p3: 3 } console.log(...obj1)
關于ES6擴展運算符的使用場景有哪些就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。