JavaScript中使用Spread运算符的八种方法总结


Posted in Javascript onJune 18, 2020

Spread运算符

允许从 iterable 表达式(如另一个数组文本)初始化部分数组文本,或允许表达式扩展到多个参数(在函数调用中)。

语法

var array = [[arg0ToN ,] ...iterable [, arg0ToN]]
func([args ,] ...iterable [, args | ...iterable])

参数

iterable

必需。 迭代对象。

arg0ToN

可选。 数组文本的一个或多个元素。

args

可选。 函数的一个或多个参数。

本文将带大家了解如何在JavaScript中使用Spread(延展操作)运算符。

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运算符的八种方法就介绍到这了,更多相关JavaScript使用Spread运算符内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

Javascript 相关文章推荐
如何做到打开一个页面,过几分钟自动转到另一页面
Apr 20 Javascript
js跨域和ajax 跨域问题的实现思路
Sep 05 Javascript
JavaScript中的索引数组、关联数组和静态数组、动态数组讲解
Nov 08 Javascript
ES6新特性之Symbol类型用法分析
Mar 31 Javascript
微信小程序 自定义消息提示框
Aug 06 Javascript
js用类封装pop弹窗组件
Oct 08 Javascript
JS 实现缓存算法的示例(FIFO/LRU)
Mar 20 Javascript
详解解决Vue相同路由参数不同不会刷新的问题
Oct 12 Javascript
Vue组件Draggable实现拖拽功能
Dec 01 Javascript
jQuery实现动态生成年月日级联下拉列表示例
May 11 jQuery
vue中input的v-model清空操作
Sep 06 Javascript
如何解决vue在ios微信"复制链接"功能问题
Mar 26 Javascript
通过实例了解JS执行上下文运行原理
Jun 17 #Javascript
从0搭建vue-cli4脚手架
Jun 17 #Javascript
微信小程序点击生成朋友圈分享图(遇到的坑)
Jun 17 #Javascript
基于JS+HTML实现弹窗提示是否确认提交功能
Jun 17 #Javascript
vue移动端的左右滑动事件详解
Jun 17 #Javascript
详解JavaScript中的Object.is()与"==="运算符总结
Jun 17 #Javascript
vue-iview动态新增和删除的方法
Jun 17 #Javascript
You might like
VFP与其他应用程序的集成
2006/10/09 PHP
php图片验证码代码
2008/03/27 PHP
php操作memcache缓存方法分享
2015/06/03 PHP
PHP实现获取ip地址的5种方法,以及插入用户登录日志操作示例
2019/02/28 PHP
自动更新作用
2006/10/08 Javascript
javascript Xml增删改查(IE下)操作实现代码
2009/01/30 Javascript
JS 事件绑定函数代码
2010/04/28 Javascript
toggle一个div显示或隐藏且可扩展成自定义下拉框
2013/09/12 Javascript
js 剪切板的用法(clipboardData.setData)与js match函数介绍
2013/11/19 Javascript
JS循环遍历JSON数据的方法
2014/07/08 Javascript
JavaScript获取Url里的参数
2014/12/18 Javascript
javascript图片滑动效果实现
2021/01/28 Javascript
基于Jquery代码实现支持PC端手机端幻灯片代码
2015/11/17 Javascript
JS简单循环遍历json数组的方法
2016/04/22 Javascript
第一次接触神奇的Bootstrap菜单和导航
2016/08/01 Javascript
动态加载css方法实现和深入解析
2017/01/18 Javascript
jQuery插件FusionCharts实现的3D帕累托图效果示例【附demo源码】
2017/03/25 jQuery
利用Decorator如何控制Koa路由详解
2018/06/26 Javascript
JavaScript进制转换实现方法解析
2020/01/18 Javascript
对YOLOv3模型调用时候的python接口详解
2019/08/26 Python
python 求定积分和不定积分示例
2019/11/20 Python
Django调用支付宝接口代码实例详解
2020/04/04 Python
python 将列表里的字典元素合并为一个字典实例
2020/09/01 Python
美国正宗奢华复古手袋、珠宝及配饰网站:What Goes Around Comes Around
2018/07/21 全球购物
编辑硕士自荐信范文
2013/11/27 职场文书
毕业生自荐信
2013/12/14 职场文书
《燕子》教学反思
2014/02/18 职场文书
公司年会抽奖活动主持词
2014/03/31 职场文书
保护环境建议书300字
2014/05/13 职场文书
师范生免费教育协议书范本
2014/10/09 职场文书
信访工作个人总结
2015/03/03 职场文书
学困生转化工作总结
2015/08/13 职场文书
互联网创业商业模式以及赚钱法则有哪些?
2019/10/12 职场文书
浅谈PHP7中的一些小技巧
2021/05/29 PHP
Python爬取英雄联盟MSI直播间弹幕并生成词云图
2021/06/01 Python
Python机器学习实战之k-近邻算法的实现
2021/11/27 Python