时间:2021-05-26
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 user = {name : "Ram", age: 20, salary: '20K', job : "Tester" };let { name, age, ...details } = user;name; // Ramage; // 20details; // {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运算符内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
一、运算符算术运算符:+-*/可以在select语句中使用连接运算符:||selectdeptno||dnamefromdept;比较运算符:>>==!=<
JavaScript运算符主要包括:算术运算符赋值运算符比较运算符三元运算符逻辑运算符字符串连接运算符算术运算符运算符说明例子运算结果+加y=2+1y=3-减y
JavaScript中的运算符有很多,主要分为算术运算符,等同全同运算符,比较运算符,字符串运算符,逻辑运算符,赋值运算符等。这些运算符都有一些属于自己的运算规
本文提供四种方法判断js数据类型,这里记录了它们之间的差异,分别是typeof运算符、instanceof运算符、constructor属性、Object.pr
JavaScript脚本语言描述了一组用于操作数据值的运算符,包括一元运算符,布尔运算符,算术运算符,关系运算符,三元运算符,位运算符和赋值运算符。表达式是Ja