首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >解构对象内的数组内的对象

解构对象内的数组内的对象
EN

Stack Overflow用户
提问于 2019-09-25 17:03:26
回答 3查看 77关注 0票数 0

我有一个对象数组,看起来像这样:

代码语言:javascript
复制
posts = [
  {
    id: 1,
    title: "abc",
    body: "lorem ipsum",
  },
  {},
] 

我想通过ES6解构来访问这棵树的最里面的键(idtitlebody)。目前,我可以通过三个阶段来实现这一点:

代码语言:javascript
复制
const { posts } = data;
const [post] = posts;
const {title, body} = post;

但我想知道是否可以在一行中做到这一点。

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2019-09-25 17:06:47

https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Operators/Destructuring_assignment

代码语言:javascript
复制
posts = [
  {
    id: 1,
    title: "abc",
    body: "lorem ipsum",
  },
  {},
];

const [{ id, title, body: newBody }] = posts
票数 1
EN

Stack Overflow用户

发布于 2019-09-25 17:06:23

这应该会完成第一个项目的工作:

代码语言:javascript
复制
let [{id, title, body}] = posts;

For循环:

代码语言:javascript
复制
posts.map(({id, title, body}) => { /* ... */})
票数 2
EN

Stack Overflow用户

发布于 2019-09-25 17:05:18

只需将posts[0]放在右边:

代码语言:javascript
复制
posts = [
  {
    id: 1,
    title: "abc",
    body: "lorem ipsum",
  },
  {},
];
const { title, body } = posts[0];

console.log(title, body);

您也可以将[]放在{}的左边,但它的可读性不是很好:

代码语言:javascript
复制
posts = [
  {
    id: 1,
    title: "abc",
    body: "lorem ipsum",
  },
  {},
];
const [{ title, body }] = posts;

console.log(title, body);

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/58094859

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档