ES6---变量的解构赋值

你好,我是小白Coding日志,一个热爱技术的程序员。在这里,我分享自己在编程和技术世界中的学习心得和体会。希望我的文章能够给你带来一些灵感和帮助。欢迎来到我的博客,一起在技术的世界里探索前行吧!

看这篇文章前先问一个问题:为什么要使用变量解构赋值?它一般在什么场景下使用?

数组的解构赋值
基本使用
let [one, two] = [1,2,3,4,5,6]
console.log(one) // 1
console.log(two) // 2

上面的代码是对数组进行的解构赋值,他将等号右边的数组元素12分别赋值给了等号左边的变量onetwo,这里需要注意一下在数组解构赋值的时候等号左边变量在数组中的位置要和等号右边数组元素的位置相对应才行;one对应的是1two对应的是2。那如果变量没找到对应的数组元素呢?

let [one, two, three, four, five, six, seven] = [1,2,3,4,5,6]
console.log(one) // 1
console.log(two) // 2
console.log(six) // 6
console.log(seven) // undefined

在上面代码中,变量seven并未找到等号右边数组中对应位置的元素,就会返回undefined

默认值

数组的解构可以提供默认值,当解构遇到undefined时,默认值就会生效。ES6内部是使用全等===运算符来确定解构是否有效。

let [one, two, three, four, five, six, seven = 7] = [1,2,3,4,5,6]
console.log(one) // 1
console.log(two) // 2
console.log(six) // 2
console.log(seven) // 7

上面的代码在解构赋值的时候当变量sevenundefined时未它设置的默认值7就会生效。

对象的解构赋值
基本使用
let { foo, baz, bar  } = { foo: 111, bar: 222, baz: 333 }
console.log(baz) // 333
console.log(foo) // 111
console.log(bar) // 222

对象的解构与数组解构有一点不同,数组的解构变量的位置必须要与等号右边的数组元素的位置相对应才能正确的解构。而对象的解构等号左边变量名需要与等号右边的对象属性名一致,能找到对应的属性名就行。上面的代码baz变量与等号右边对象中对应的baz属性的位置不一致,但也找到了对应的属性名,所以无需关注对象属性的位置。

let { log } = console
log('xxxx') // xxxx

上面的代码对console对象进行了解构,将log属性赋值给了log变量并在控制台打印了xxxx
那如果变量名与属性名不一致呢?可以这么写:

let {foo: ccc, baz: ddd } = { foo: 111, bar: 222, baz: 333 }
console.log(ccc) // 111
console.log(ddd) // 333

上面的代码等号左边变量名与等号右边属性名不一致写成了foo: ccc实际上访问的变量ccc,这么写ES6会先去找同名属性foo,然后再将属性对应的值赋值给变量ccc

let { foo: foo, bar: bar, baz: baz } = { foo: 111, bar: 222, baz: 333 }
console.log(baz) // 333
console.log(foo) // 111
console.log(bar) // 222

实际上,上面代码的写法才是对象解构赋值的标准写法,开头那段代码是它的简写形式。对象解构赋值内部机制其实是:先找到变量对应同名属性,然后将属性名对应的值赋值给变量。

const obj = {
  o: {
    y: 'yyy',
    p: {
      x: 'xxx'
    }
  }
}
const { o, o:{ y, p: { x }}} = obj
console.log(o) // {"y": "yyy","p": {"x": "xxx"}}
console.log(y) // yyy
console.log(x) // xxx

上面是一个嵌套的对象通过解构赋值将obj对象对应的属性值赋值给了同名变量

默认值
let { name, age, Gender = '男'} = { name: 'xiaobaiCoding', age: 26 }
console.log(name) // xiaobaiCoding
console.log(Gender) // 男
console.log(age) // 26

上面的代码为Gender变量提供了一个默认值,实际上在等号右边的对象中并没有Gender属性,ES6未找到Gender 属性就返回undefined,此时如果Gender变量提供了默认值那就会使用默认值。

let { name, age, Gender = '男'} = { name: 'xiaobaiCoding', age: 26 , Gender: '女'}
console.log(name) // xiaobaiCoding
console.log(Gender) // 女
console.log(age) // 26

如果Gender属性有值并不为undefined那提供的默认值肯定就不会生效咯。那如果显式的把一个属性值设置为undefined会有什么效果呢?

let { name, age, Gender = '男'} = { name: 'xiaobaiCoding', age: 26 , Gender: undefined}
console.log(name) // xiaobaiCoding
console.log(Gender) // 男
console.log(age) // 26

我们看到默认值生效了!那我们由此得到结论:默认值生效的机制是变量对应的属性值为undefined的时候

字符的串解构赋值
let [a, b, c, d] = "xiaobai"
console.log(a) // x
console.log(b) // i
console.log(c) // a
console.log(d) // o

字符串也可以解构赋值,上面的代码对字符串xiaobai做了解构赋值,此时字符串被转成一个类似数组的对象

let { length } = "coding"
console.log(length) // 6

类似数组的对象都有一个length属性,所以可以对字符串的属性进行解构

数值和布尔值解构赋值

如果等号右边的是数值或布尔值,会先将其转为对象。

let {toString: s} = 123
console.log(s === Number.prototype.toString) // true
let {toString: f} = true
console.log(f === Boolean.prototype.toString) //true

上面的代码对布尔值和数值进行了解构赋值,ES6先将其转为了一个对象,因为布尔值和数值包装对象都有toString属性,所以s === Number.prototype.toString这句代码返回的是true在解构赋值的时候,等号右边如果不是对象或数组会ES6会将其先转为一个对象,nullundefined无法转为一个对象,对他们进行解构赋值会报错。

let {prop: x} = null
let {prop: y} = undefined
console.log(x) // TypeError
console.log(y) // TypeError
函数参数的解构赋值
基本使用
function add([a, b]){
  return a + b
}
console.log(add([2,3])) // 5

上面的代码对函数的参数进行了解构赋值,调用add的时候传入的参数是一个数组,add函数接受到这个参数被解构成了ab两个变量,实际上函数内部使用到的ab并返回了a+b的结果

默认值
function add2({x = 1, y = 2} = {}){
  return x * y
}
console.log(add2({x: 2, y: 10})) // 20
console.log(add2({x: 2})) // 4
console.log(add2({})) // 2
console.log(add2()) // 2

上面代码为函数参数提供了默认值,调用时传入不同的参数返回对应的结果
现在可以回答最开始那个问题了,有时候一个对象中可能会包含很多的属性,而我们其实只需要其中的目一个或某几个属性,这时候使用变量解构赋值能更方便的从对象或数组中取出自己想要的某个值并赋值个一个变量,而且还能给变量设置默认值,当等号右边某个对象属性值为undefined时防止程序执行到哪里的时候报错。

最后还是那句话:即使代码逻辑很简单,也值得记录下来。我的编程目标是避免重复造轮子!😊
如果觉得有用,就给我点个赞吧😁
探索更多有趣知识,欢迎关注我的微信公众号:小白Coding日志,每天分享精彩内容,与你一同探寻知识的边界。一起开启知识新旅程!🚀📚
关注我的技术博客,探索前沿科技与实用开发技巧。一起携手走向代码的精彩世界!🚀💻 不错过每一篇精彩!

https://www.xiaobaicoding.com

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mfbz.cn/a/774811.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

JVM专题之性能优化

运行时优化 方法内联 > 方法内联,是指 **JVM在运行时将调用次数达到一定阈值的方法调用替换为方法体本身** ,从而消除调用成本,并为接下来进一步的代码性能优化提供基础,是JVM的一个重要优化手段之一。 > > **注:** > > * **C++的inline属于编译后内联,…

特殊用途二极管+二极管故障检测+三极管(BJT)的工作原理+定时器的使用(小灯定时闪烁实现)

2024-7-5,星期五,17:27,天气:晴,心情:晴。今天没有什么特殊的事情发生,继续学习啦,加油加油!!! 今日完成模电自选教材第二章内容的学习&#xff…

Linux-C语言实现一个进度条小项目

如何在linux中用C语言写一个项目来实现进度条?(如下图所示) 我们知道\r是回车,\n是换行(且会刷新) 我们可以用 \r 将光标移回行首,重新打印一样格式的内容,覆盖旧的内容,…

二重积分 - 包括计算方法和可视化

二重积分 - 包括计算方法和可视化 flyfish 计算在矩形区域 R [ 0 , 1 ] [ 0 , 2 ] R [0, 1] \times [0, 2] R[0,1][0,2] 下,函数 z 8 x 6 y z 8x 6y z8x6y 的二重积分。这相当于计算曲面 z 8 x 6 y z 8x 6y z8x6y 与 xy 平面之间的体积。 二重积分…

网页计算器的实现

简介 该项目实现了一个功能完备、交互友好的网页计算器应用。只使用了 HTML、CSS 和 JavaScript ,用于检验web前端基础水平。 开发环境:Visual Studio Code开发工具:HTML5、CSS3、JavaScript实现效果 功能设计和模块划分 显示模块&#…

Chapter11让画面动起来——Shader入门精要学习笔记

Chapter11让画面动起来 一、Unity Shader中的内置变量(时间篇)二、纹理动画1.序列帧动画2.滚动背景 三、顶点动画1.流动的河流2.广告牌3.注意事项①批处理问题②阴影投射问题 一、Unity Shader中的内置变量(时间篇) Unity Shader…

Chiasmodon:一款针对域名安全的公开资源情报OSINT工具

关于Chiasmodon Chiasmodon是一款针对域名安全的公开资源情报OSINT工具,该工具可以帮助广大研究人员从各种来源收集目标域名的相关信息,并根据域名、Google Play应用程序、电子邮件地址、IP地址、组织和URL等信息进行有针对性的数据收集。 该工具可以提…

window系统openssl开发环境搭建(VS2017)

window系统openssl开发环境搭建 VS2017 一、下载openssl二、安装openssl三、openssl项目配置3.1 配置include文件3.2 配置openssl动态库四、编写openssl测试代码五、问题总结5.1 问题 一5.2 问题二一、下载openssl https://slproweb.com/products/Win32OpenSSL.html 根据自己…

如何查看MCU编译生成的elf(out)文件内容

一般地,我们想要知道单片机程序编译完后的结构我们可以查看map文件或者是elf/out文件,map文件不能看函数的汇编格式,只能查看编译完成后变量、代码的地址和占用空间大小,而elf文件里面更加详细,还包含了函数的汇编&…

CobaltStrike的内网安全

1.上线机器的Beacon的常用命令 2.信息收集和网站克隆 3.钓鱼邮件 4.CS传递会话到MSF 5.MSF会话传递到CS 1上线机器的Beacon的常用命令 介绍:CobaltStrike分为服务端和客户端,一般我们将服务端放在kali,客户端可以在物理机上面&#xff0…

跨境人最怕的封店要怎么规避?

跨境人最怕的是什么?——封店 造成封店的原因很多,IP关联、无版权售卖、虚假发货等等,其中IP关联这个问题导致店铺被封在跨境商家中简直是屡见不鲜 IP关联,是指被海外平台检测到多家店铺开设在同一个站点上的情况。我们知道有些…

您的私人办公室!-----ONLYOFFICE8.1版本的桌面编辑器测评

随时随地创建并编辑文档,还可就其进行协作 ONLYOFFICE 文档是一款强大的在线编辑器,为您使用的平台提供文本文档、电子表格、演示文稿、表单和 PDF 编辑工具。 网页地址链接: https://www.onlyoffice.com/zh/office-suite.aspxhttps://www…

“拆分盘投资:机遇与风险并存

一、引言 随着互联网技术的日新月异,金融投资领域迎来了前所未有的变革,其中拆分盘作为一种新兴的投资模式,正逐渐进入公众的视野。其独特的价值增长逻辑和创新的投资机制,为投资者开辟了新的财富增值渠道。本文旨在深入探讨拆分…

tinyshop商城学习

1、使用badboy屏幕录制工具,获得服装购物业务的结果,生成.jmx文件 2、在JMeter中新建线程组,导入.jmx文件 3、完成进入商城,登录,服装页面进入,随机选择服装,添加购物车,开始结算&…

WAIC上官宣!大模型语料提取工具MinerU正式发布,开源免费“敲”好用

7月4日,2024 WAIC科学前沿全体会议在上海世博中心红厅隆重举行。上海人工智能实验室与商汤科技联合香港中文大学和复旦大学正式发布新一代大语言模型书⽣浦语2.5(InternLM2.5),同时全链条工具体系迎来重磅升级,对于大模…

第六篇——谋攻篇:上兵伐谋,不是说打仗要用计谋

目录 一、背景介绍二、思路&方案三、过程1.思维导图2.文章中经典的句子理解3.学习之后对于投资市场的理解4.通过这篇文章结合我知道的东西我能想到什么? 四、总结五、升华 一、背景介绍 战术层面的东西,即便战略对了,战术不对&#xff0…

公司管理系统

准备工作 上图mapper类型错了,不是class,是interface,修正过后的图片,如下所示 修正如下 spring.datasource.driver-class-namecom.mysql.cj.jdbc.Driver spring.datasource.urljdbc:mysql://localhost:3306/webm spring.datasour…

CAN总线(上)

CAN总线(Controller Area Network Bus)控制器局域网总线 CAN总线是由BOSCH公司开发的一种简洁易用、传输速度快、易扩展、可靠性高的串行通信总线,广泛应用于汽车、嵌入式、工业控制等领域 CAN总线特征: 两根通信线(…

关于ORACLE单例数据库中的logfile的切换、删除以及添加

一、有关logfile的状态解释 UNUSED: 尚未记录change的空白group(一般会出现在loggroup刚刚被添加,或者刚刚使用了reset logs打开数据库,或者使用clear logfile后) CURRENT: 当前正在被LGWR使用的gro…

产科管理系统 专科电子病历系统源码,前后端分离架构,多家医院产科广泛运用,系统稳定,功能齐全

产科管理系统 专科电子病历系统源码,前后端分离架构,多家医院产科广泛运用,系统稳定,功能齐全 产科管理系统,特别是产科信息管理系统(Obstetrical Information Management System,简称OIMS&…