【es6】对象解构赋值

es6中对象解构赋值:

代码

javascript 复制代码
let { foo: baz } = { foo: 'rose', bar: 'jeck' };
baz // "rose"

let obj = { first: 'tom', last: 'rose' };
let { first: f, last: l } = obj;
f // 'tom'
l // 'rose'

let { foo: baz } = { foo: 'rose', bar: 'jeck' }中的foo:baz部分,foo是匹配对象中属性名称foo,baz则是需要被赋值的变量。

对象赋值还可以用于嵌套的对象赋值:

代码:

javascript 复制代码
let obj = {
  p: [
    'rose',
    { y: 'jeck' }
  ]
};

let { p: [x, { y }] } = obj;
x // "rose"
y // "jeck"

let { p: [x, { y }] }中的p属于匹配对象中p属性,需要被赋值的变量为x、y。

下面给出另外一个模式匹配赋值,嵌套类型的。

javascript 复制代码
let obj = {
  p: [
    'rose',
    { y: 'jeck' }
  ]
};

let { p, p: [x, { y }] } = obj;
x // "roes"
y // "jeck"
p // ["rose", {y: "jeck"}]

let { p, p: [x, { y }] } = obj中的第一个p其实是p:p的简写,p: [x, { y }] 中的p是模式,匹配对象中属性p,然后将数组内的第一个值赋值给x,第二个值的y属性赋值给y,y也是y:y的简写。详细写法是:let { p:p, p: [x, { y:y }] } = obj

相关推荐
am心9 分钟前
企业开发项目流程记录
java
小彭努力中20 分钟前
191.Vue3 + OpenLayers 实战:可控化版权信息(Attribution)详解与完整示例
前端·javascript·vue.js·#地图开发·#cesium
奇舞精选22 分钟前
用去年 github 最火的 n8n 快速实现自动化推送工具
前端·agent
奇舞精选26 分钟前
实践:如何为智能体推理引入外部决策步骤
前端·agent
无限大633 分钟前
AI实战02:一个万能提示词模板,搞定90%的文案/设计/分析需求
前端·后端
独自破碎E1 小时前
前后端分离+微服务架构下的用户认证
java·面试·架构
朝阳5811 小时前
控制 Nuxt 页面的渲染模式:客户端 vs 服务端渲染
前端·javascript
hssfscv1 小时前
力扣练习训练2(java)——二叉树的中序遍历、对称二叉树、二叉树的最大深度、买卖股票的最佳时机
java·数据结构·算法
发现一只大呆瓜1 小时前
Vue-Vue2与Vue3核心差异与进化
前端·vue.js·面试
Byron__1 小时前
HashMap面试知识点
java·面试·hash