在JavaScript中使用延展操作運算符的8種方法
ES6中引入了延展操作運算符(...)。
延展操作運算符將可迭代的對象擴展為其單獨的元素,可迭代對象是可以使用 for 循環(huán)進行循環(huán)的任何對象。
可迭代的示例:Array,String,Map,Set,DOM節(jié)點。
1. 在log中使用延展操作運算符
你可以在 console.log 中對可迭代對象使用延展操作操作符
- let fruits = ['', '', '', ''];
- console.log(...fruits); //
2. 用延展操作運算符復制數(shù)組
- let fruits = ['', '', '', ''];
- let fruitsCopy = [ ...fruits ];
- console.log(...fruitsCopy); //
復制對象
- let user = {name : "John", age : 20 }
- let userCopy = {...user}
延展操作運算符不執(zhí)行深度復制。
3. 延展操作運算符合并
- let fruits = ['', '', '', ''];
- let vegetables = ['', '', ''];
- let fruitsAndVeg = [...fruits, ...vegetables]
合并對象
合并對象時,如果已經存在某個鍵,則將其替換為具有相同鍵的最后一個對象。
- let user1 = {name : "John", age : 20 };
- let user2 = {name : "Ram", salary: '20K' };
- let userCopy = {...user1, ...user2};
- userCopy ; // {name : "Ram", age :20 , salary : '20K'};
4. 延展操作運算符作為參數(shù)傳遞
- function sum(a, b) {
- return a+b;
- }
- let num = [1,2];
- sum(...num); // 3
與 math 函數(shù)一起使用
- let num = [5,9,3,5,7];
- Math.min(...num);
- Math.max(...num);
5. 延展操作運算符在解構變量中
- let [melon, ...fruits ] = ['', '', '', ''];
- melon; //
- fruits; // [ '', '', '']
解構對象
- 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對象轉換為數(shù)組
NodeList類似于數(shù)組,但是沒有 Array 的所有方法,例如 forEach,map,filter 等。
- let nodeList = document.querySelectorAll('.class')
- var nodeArray = [...nodeList]
7. 將字符串轉換為字符
字符串也是可迭代的對象,因此我們也可以使用 ... 來字符串。
- let name = "Ram";
- let chars = [...name]; // ["R", "a", "m"]
8. 從數(shù)組中刪除重復項
- let num = [1, 3, 1, 3, 3, 1];
- let uniqueNum = [...new Set(num)];
- uniqueNum; //[ 1, 3 ]