首頁 >web前端 >js教程 >JavaScript中如何使用Spread運算子(...)? 8種方法介紹

JavaScript中如何使用Spread運算子(...)? 8種方法介紹

青灯夜游
青灯夜游轉載
2020-06-29 10:40:382678瀏覽

JavaScript中如何使用Spread運算子(...)? 8種方法介紹

ES6中引入了延展操作運算子(...)。

延展操作運算子將可迭代的物件擴展為其單獨的元素,可迭代物件是可以使用 for 循環進行循環的任何物件。

可迭代的範例:Array,String,Map,Set,DOM節點。

1.在log中使用延展運算子運算子

#你可以在console.log 中對可迭代物件使用延展操作運算子

JavaScript中如何使用Spread運算子(...)? 8種方法介紹

2.用延展運算子複製陣列

JavaScript中如何使用Spread運算子(...)? 8種方法介紹

複製物件

       

let user = {name : "John", age : 20 }
let userCopy = {...user}
延展作業運算子不執行深度複製。

3.延展操作運算符合並

JavaScript中如何使用Spread運算子(...)? 8種方法介紹

合併物件

合併對象時,如果已經存在某個鍵,則將其替換為具有相同鍵的最後一個物件。

let user1 = {name : "John", age : 20 };
let user2 = {name : "Ram", salary: '20K' };
let userCopy = {...user1, ...user2};
userCopy ; // {name : "Ram", age :20 , salary : '20K'};

4.延展運算子作為參數傳遞

function sum(a, b) {
   return a+b;
}
let num = [1,2];
sum(...num); // 3

math 函數一起使用

let num = [5,9,3,5,7];
Math.min(...num);
Math.max(...num);

5.延展運算元在解構變數中

JavaScript中如何使用Spread運算子(...)? 8種方法介紹

解構物件

let user = {name : "Ram", age: 20, salary: '20K', job : "Tester" };
let { name, age, ...details } = user;
name; // Ram
age; // 20
details; // {salary: '20K', job : 'Tester'};

#6.將NodeList物件轉換為陣列

NodeList類似於數組,但是沒有Array 的所有方法,例如forEachmapfilter 等。

let nodeList = document.querySelectorAll('.class')
var nodeArray = [...nodeList]

7.將字串轉換為字元

字串也是可迭代的對象,因此我們也可以使用. .. 來字串。

let name = "Ram";
let chars = [...name]; // ["R", "a", "m"]

8.從陣列中刪除重複項

#
let num = [1, 3, 1, 3, 3, 1];
let uniqueNum = [...new Set(num)];
uniqueNum; //[ 1, 3 ]

原文位址:https://medium.com/javascript- in-plain-english/8-ways-to-use-spread-operator-in-javascript-b66fcf016efe

作者:Javascript Jeep

##轉載自:https://segmentfault.com/ a/1190000023023909

相關教學推薦:

JavaScript影片教學

以上是JavaScript中如何使用Spread運算子(...)? 8種方法介紹的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文轉載於:segmentfault.com。如有侵權,請聯絡admin@php.cn刪除