在JavaScript中使用延展操作运算符的8种方法

ES6中引入了延展操作运算符(...)。中使展操作运

延展操作运算符将可迭代的用延对象扩展为其单独的元素,可迭代对象是算符可以使用 for 循环进行循环的任何对象。

可迭代的中使展操作运示例:Array,String,用延Map,亿华云计算算符Set,中使展操作运DOM节点。用延

1. 在log中使用延展操作运算符

你可以在 console.log 中对可迭代对象使用延展操作操作符

let fruits = [,算符 , , ]; console.log(...fruits); //    

2. 用延展操作运算符复制数组

let fruits = [, , , ]; let fruitsCopy = [ ...fruits ];  console.log(...fruitsCopy); //  

复制对象

let user = { name : "John", age : 20 } let userCopy = { ...user} 

延展操作运算符不执行深度复制。

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. 延展操作运算符作为参数传递

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. 延展操作运算符在解构变量中

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对象转换为数组

NodeList类似于数组,但是用延没有 Array 的云服务器所有方法,例如 forEach,算符map,filter 等。

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 ] 
滇ICP备2023000592号-31