了解如何在JavaScript中使用Spread(延展操作)运算符。

成都创新互联公司专注于企业全网整合营销推广、网站重做改版、二道江网站定制设计、自适应品牌网站建设、成都h5网站建设、商城开发、集团公司官网建设、成都外贸网站建设公司、高端网站制作、响应式网页设计等建站业务,价格优惠性价比高,为二道江等各大城市提供网站开发制作服务。
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中使用Spread运算符的8种方法
                
                当前地址:http://www.csdahua.cn/qtweb/news19/293319.html
            
网站建设、网络推广公司-快上网,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 快上网