当前位置: 首页 > news >正文

js对象解构语法

对象解构语法是一种 JavaScript 的语法特性,用于从对象中提取属性,并将这些属性值赋值给变量。

基本语法

const { property1, property2 } = object;
  • object 是要解构的对象。
  • property1property2 是对象中的属性名,用花括号 {} 包裹起来表示从对象中提取这些属性。
  • 解构后的属性值会分别赋值给同名的变量 property1property2

默认值

如果对象中没有提取的属性,则解构后的变量将会是 undefined。可以使用默认值来避免这种情况。

const { property1 = defaultValue1, property2 = defaultValue2 } = object;
  • 如果 object 中没有 property1 属性,则 property1 变量的值为 defaultValue1
  • 如果 object 中没有 property2 属性,则 property2 变量的值为 defaultValue2

重命名

可以使用冒号 : 来重命名解构后的变量名。

const { property1: newName1, property2: newName2 } = object;
  • property1 属性的值会赋值给 newName1 变量。
  • property2 属性的值会赋值给 newName2 变量。

解构嵌套对象

对象解构语法也可以用于解构嵌套对象。

const { property1: { nestedProperty1, nestedProperty2 } } = object;
  • object 中的 property1 属性是一个对象,其中包含 nestedProperty1nestedProperty2 属性。
  • 这些属性值会分别赋值给 nestedProperty1nestedProperty2 变量。

示例

const person = { name: 'John', age: 30, city: 'New York' };const { name, age } = person;
console.log(name); // 输出 'John'
console.log(age); // 输出 30const { name: fullName, age: years } = person;
console.log(fullName); // 输出 'John'
console.log(years); // 输出 30const { gender = 'Male', city } = person;
console.log(gender); // 输出 'Male',因为 person 中没有 gender 属性,所以使用了默认值
console.log(city); // 输出 'New York'const { address: { street, zip } } = person; // person 没有 address 属性,会导致解构错误

总的来说,对象解构语法使得从对象中提取属性变得更加简洁和方便,并且可以轻松地使用默认值、重命名属性、解构嵌套对象等功能。

http://www.lryc.cn/news/312191.html

相关文章:

  • flowable使用taskService.addComment新增评论需要full_msg字段进行读取
  • java常用技术栈,java面试带答案
  • 刷题第11天
  • QML中动态增加表格数据
  • OBS插件开发(二)推流实时曲线
  • Linux编程3.3 进程-进程的终止
  • 排序(3)——直接选择排序
  • [LeetBook]【学习日记】数组内重组
  • 【Linux】磁盘情况、挂载,df -h无法看到的卷
  • AIOps实践中常见的挑战:故障根因与可观测性数据的割裂
  • python 远程代码第一次推送
  • C++开发基础之简单的计时器也有适配场景
  • 数电学习笔记——逻辑函数及其描述方法
  • 2024年护眼台灯哪家品牌好?五款优质品牌专业推荐
  • 搜索iconfont或者阿里图标就可以得到免费的图标
  • android实战视频教程,细数Android开发者的艰辛历程
  • nav2_gps_waypoint_follower_demo 不能在ros2 humble中直接使用的解决方法
  • 华为OD机试 - 螺旋数字矩阵
  • Vue响应式内容丢失处理
  • Linux安装Rabbitmq
  • 在nginx 服务器部署vue项目
  • 制作一个简单的HTML个人网页
  • HM2019创建载荷工况
  • Effective C++ 学习笔记 条款14 在资源管理类中小心copying行为
  • c++数据结构算法复习基础-- 3 --线性表-单向链表-笔试面试常见问题
  • 【踩坑专栏】追根溯源,从Linux磁盘爆满排查故障:mycat2与navicat不兼容导致日志暴增
  • DolphinScheduler——奇富科技的调度实践
  • 2024年最全洗地机选购攻略盘点丨希亦、小米、云鲸、海尔洗地机哪款值得入手?
  • HTML笔记3
  • 利用Python副业赚钱,看完这篇你就懂了!