首页 > 其他分享 >JS中的 解构、可扩展运算符(...)

JS中的 解构、可扩展运算符(...)

时间:2024-09-13 16:48:03浏览次数:16  
标签:... arr const console 解构 运算符 obj

一、解构([x, x, x] =[1, 2, 3])

解构,英文名叫Destructuring。核心就是 [A, B, C] = [1, 2, 3]这种形式。其核心思想就是把数组/对象的每个元素解构出来。虽然这话说的很抽象,但举个例子你就明白了。

1.1 数组解构

const [a, b, c] = [1, 2, 3]
console.log(a) //1
console.log(b) //2
console.log(c) //3
结构核心思路

如上图所示,结构基本核心思路就是这样,相当简单,1解构给a,2解构给b,3解构给c。

对于嵌套数组,解构方法也是也是一样的,我个人比较喜欢这样写:

const arr = [1, 2, 3, [4, 5]]
      const [a, b, c, [d, e]] = arr //为了方便理解,我在这行代码前面多打了几个空格

1.2 对象

对象也差不多的啦,比如说:

const obj = {
    "userId": 1,
    "id": 1,
    "title": "sunt aut facere repellat provident occaecati excepturi optio reprehenderit",
    "body": "quia et suscipit\nsuscipit recusandae consequuntur expedita et cum\nreprehenderit molestiae ut ut quas totam\nnostrum rerum est autem sunt rem eveniet architecto"
  }
const {userId, id, title, body} = obj

对象解构和数组解构唯一的区别在于,对象要保证key的名称是相同的才能解构,如果名称不同,则解构不成功。另外解构出来的key命名你不喜欢,你可以reName。比如:

const {userId, id, title, body:textBody} = obj
console.log(textBody)

对于嵌套对象,只需要解构出来重复刚刚的解构过程即可,比如说:

const obj = {
   a:1,
   b:2,
   c:{
    d:3,
    e:4
  }
}
// 方法1:
const {a, b, {d, e}} = obj

// 方法2:(个人喜欢这种,嵌套对象的方法1这种写法看着很让人疑惑)
const {a, b, c} = obj
const {d, e} = c //对c这个对象再进行一步解构

二、Spread and rest Operator(...)

中文似乎叫可扩展运算符,但我特意标题写英文是因为英文好理解一些。特征就是三个点...

其实我特意写上面的英文是因为,这个ES6的语法是包括两部分的,也就是Spread和rest

2.1 rest(收拢)

rest语法允许我们将一个不定数量的参数表示为一个数组。

这是MDN的语录,划分一下主谓宾,一般来说就是将多个参数拼成数组(多个参数 => 数组),但如果你对对象{}使用,则是收拢成对象。啥意思呢,举个例子:

function sum(multiplier, ...numbers){
     console.log(numbers) // [4, 2]
     return  multiplier * numbers.reduce((sum ,number) => sum + number, 0)
}

sum(10, 4, 2) //60 因为10* (4+2)


const obj = { a:1, b:2, c:3, d:{e:4} }
const {a, b, ...rest} = obj // 意思是a, b解构出来,obj剩余参数则收拢在一起
//只不过此时收拢后的结果不是数组,而是收拢在一起成为对象
console.log(rest) //{c:3, d:{e:4}}

如上面代码所示,打印numbers时,是一个数组[4, 2],正如上面MDN所定义的,rest语法让我们将多个参数合并成一个数组。参数10时属于multiplier的,剩余参数4,2自然就被...numbers拼成了数组。

2.2 Spread(展开)

相比于rest,聚拢在一起,Spread则是展开,比如:

const names = ["Kyle", "Cook"]
function concatName(firstName, lastName){ 
    console.log(firstName + "" + lastName)
}

concatName(...names) // Kyle Cook

2.3 小结

rest Operator则是把多个参数收拢,Spread则是把聚在一起的元素展开。

收拢:则是把元素收拢在一起,变成一个数组。

展开:则是把数组/对象展开,拿到里面的每个元素。

在使用...时,注意自己用的是spread还是rest,比如说有个变量numbers,你 ...numbers,你应该想想自己用的是展开(rest),还是收拢(spread)

2.4 拷贝

...最有用的就是拷贝一份全新的数组/对象,比如说:

const arr = [1, 2, 3]
const newArr = [...arr] //把arr展开,然后再用[]创建一个新数组,最后把创建出来的数组赋值给newArr

// 简化模型理解就是:
// const newArr = [arr[0], arr[1], arr[2]] 就是这么个意思

另外我想提及的一点就是,拷贝其实跟赋值完全不是一个概念,拷贝会开辟一个新地址,啥意思呢?比如说:

1>这是拷贝的:

const arr = [1, 2, 3]
const newArr = [...arr]
newArr.push(100)

console.log(arr) // [1, 2, 3]
console.log(newArr) // [1, 2, 3, 100]

2>这是赋值:

const arr = [1, 2, 3]
const newArr = arr
newArr.push(100)

console.log(arr) // [1, 2, 3, 100]
console.log(newArr) // [1, 2, 3, 100]

我有一篇文章介绍过赋值的情况lzb123:Reference vs Value,简单来说,就是拷贝时,arr地址是0x01,newArr地址是0x02。但赋值时arr和newArr地址都是0x01。因为赋值时你把arr地址赋值给了newArr。所以它两共用一个地址。

2.5 拷贝注意事项

就是如果拷贝时,后面的有一个key跟前面的一样,则以排在后面的key的值为准,请让我举个例子解释一下:

const obj = {a: 1, b: 2, c: 3}
const newObj = {...obj, c: 4} //拷贝时,后面的key(指的是c)和前面展开obj时出现的c这个key是一样的
//所以以后面的c的值为准
console.log(newObj)  //{a: 1, b: 2, c: 4}

//哪个c在后面以哪个为准
const newObj2 = {c:4, ...obj}
console.log(newObj2) //{a: 1, b: 2, c: 3} 此时,以后面那个c,也就是obj展开后的c:3为准

简单来说,拷贝时,碰到一样的key,哪个key排在后面,以哪个key的值为准。

标签:...,arr,const,console,解构,运算符,obj
From: https://www.cnblogs.com/itjeff/p/18412488

相关文章

  • 网站打开提示:”未检测到您服务器环境的sqlite3数据库扩展...“
    当你的网站打开时提示“未检测到您服务器环境的sqlite3数据库扩展”,这意味着你的PHP环境缺少对SQLite3的支持。SQLite3是一个轻量级的数据库引擎,它作为PHP的一个扩展来提供支持。要解决这个问题,你可以按照以下步骤操作:1.检查PHP版本首先确认你的PHP版本支持SQLite3。SQLite3支......
  • C++中的基本运算符----逻辑运算符(&&、||、!)的实例讲解
    在C++中,逻辑运算符用于处理布尔值(true和false),并用于复合条件的判断。主要的逻辑运算符包括:目录1.逻辑与运算符(&&):2.逻辑或运算符(||):3.逻辑非运算符(!):1.逻辑与运算符(&&):当且仅当两个操作数都为true时,结果才为true。示例:if(a>0&&b>0)下面......
  • 985硕士,最近投了100多份大模型算法岗,没下文...
    我是丁师兄,专注于智能驾驶方向大模型落地,公众号:丁师兄大模型。大模型1v1学习,已帮助多名同学上岸国内外大厂今天给大家分享一下,从面试官的视角看,什么样的简历算一份优质的简历?以及如何快速把简历改好。为什么想讲这个呢?因为最近我也在集中面试嘛,看了N多份简历,大部分人的......
  • 【C语言基础】数据类型、运算符和表达式
    1数据类型基本类型整型:短整型,基本整型,长整型字符型实型(浮点型):单精度型,双精度型枚举类型构造类型:是使用基本类型的数据或者使用已经构造好的数据类型,进行添加、设计构造出新的数据类型,使其设计的新构造类型满足待解决问题所需要的数据类型。数组类型结构体类型共用体类......
  • 【编程基础知识】mysql中的insert into ... on DUPLICATE key和replace into的性能对
    一、概述在MySQL中,INSERTINTO...ONDUPLICATEKEYUPDATE和REPLACEINTO都是用来处理插入或更新数据的语句,但它们在性能和行为上有所不同。二、REPLACEINTOREPLACEINTO语句在遇到唯一键或主键冲突时,会先删除旧记录,然后插入新记录。这意味着它会执行两次操作:删除......
  • Python(二)-运算符
    常见的运算符(1)算术运算符:+、-、*、/、//、%、**;(2)赋值运算符:=、+=、-=、*=、/=、//=、%=、**=;(3)比较运算符:>、<、>=、<=、==、!=;(4)逻辑运算符:not、and、or。算术运算符算术运算符名称描述+加法两个数相加,如6+12=18。-减法两个数相减,如25-9=16。*乘法两个数相乘,如3*7=......
  • 22级五年制C语言入门教程-(6)运算符
    1.运算符概述运算符是一种编译器执行特定的数学或逻辑操作的符号。C语言提供了以下类型的运算符:算术运算符关系运算符逻辑运算符位运算符赋值运算符条件运算符其他运算符2.算术运算符算术运算符分为单目运算符和双目运算符,单目运算符表示只需要一个操作数,双目运算符需......
  • 震惊!!一男子用尽了各种方式都搜不到这个资源,于是他竟然将手伸向了......!?pyqt pyside
    震惊!!一男子用尽了各种方式都搜不到这个资源,于是他竟然将手伸向了......!?pyqtpyside随窗口自适应、可缩放、拖动QLabel需求场景实现功能和使用1.参数设置2.设置图片3.缩放4.拖动5.小惊喜(裁剪图片)完整使用案例1.使用QtDesigner设计一个简单界面2.引用制......
  • 因为不懂推测解码,被面试官鄙视了...
    我是丁师兄,专注于智能驾驶方向大模型落地,公众号:丁师兄大模型。大模型1v1学习,已帮助多名同学上岸国内外大厂前两天有个学员抱怨后天就要面试了,心里难免紧张。尽管他做了很多准备,但他还是担心面试官会问到像“大模型中的推测解码”这种复杂的技术问题。为了不在关键时刻掉链......