在JavaScript中如何使用延展操作运算符

本篇内容主要讲解“在JavaScript中如何使用延展操作运算符”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“在JavaScript中如何使用延展操作运算符”吧!

创新互联专注于北屯网站建设服务及定制,我们拥有丰富的企业做网站经验。 热诚为您提供北屯营销型网站建设,北屯网站制作、北屯网页设计、北屯网站官网定制、微信小程序定制开发服务,打造北屯网络公司原创品牌,更为您提供北屯网站排名全网营销落地服务。

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 ]

到此,相信大家对“在JavaScript中如何使用延展操作运算符”有了更深的了解,不妨来实际操作一番吧!这里是创新互联网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!


当前题目:在JavaScript中如何使用延展操作运算符
转载注明:http://csdahua.cn/article/ieecso.html
扫二维码与项目经理沟通

我们在微信上24小时期待你的声音

解答本文疑问/技术咨询/运营咨询/技术建议/互联网交流