如何合并这些父/子javascript对象?

时间:2019-10-14 05:15:14

标签: javascript json

我正在使用两个json API端点,一个端点返回“ posts”,另一个返回与这些帖子关联的“ comments”。例子:

/*posts*/
[
  {
    "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"
  },
  {
    "userId": 1,
    "id": 2,
    "title": "qui est esse",
    "body": "est rerum tempore vitae\nsequi sint nihil reprehenderit dolor beatae ea dolores neque\nfugiat blanditiis voluptate porro vel nihil molestiae ut reiciendis\nqui aperiam non debitis possimus qui neque nisi nulla"
  },
  {
    "userId": 1,
    "id": 3,
    "title": "ea molestias quasi exercitationem repellat qui ipsa sit aut",
    "body": "et iusto sed quo iure\nvoluptatem occaecati omnis eligendi aut ad\nvoluptatem doloribus vel accusantium quis pariatur\nmolestiae porro eius odio et labore et velit aut"
  }
]

/*comments*/
[
  {
    "postId": 1,
    "id": 1,
    "name": "id labore ex et quam laborum",
    "email": "Eliseo@gardner.biz",
    "body": "laudantium enim quasi est quidem magnam voluptate ipsam eos\ntempora quo necessitatibus\ndolor quam autem quasi\nreiciendis et nam sapiente accusantium"
  },
  {
    "postId": 1,
    "id": 2,
    "name": "quo vero reiciendis velit similique earum",
    "email": "Jayne_Kuhic@sydney.com",
    "body": "est natus enim nihil est dolore omnis voluptatem numquam\net omnis occaecati quod ullam at\nvoluptatem error expedita pariatur\nnihil sint nostrum voluptatem reiciendis et"
  },
  {
    "postId": 1,
    "id": 3,
    "name": "odio adipisci rerum aut animi",
    "email": "Nikita@garfield.biz",
    "body": "quia molestiae reprehenderit quasi aspernatur\naut expedita occaecati aliquam eveniet laudantium\nomnis quibusdam delectus saepe quia accusamus maiores nam est\ncum et ducimus et vero voluptates excepturi deleniti ratione"
  }
]

我的最终结果应该是(使用第一篇文章作为模板):

[
   {
      "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",
      "comments":[
         {
            "postId":1,
            "id":1,
            "name":"id labore ex et quam laborum",
            "email":"Eliseo@gardner.biz",
            "body":"laudantium enim quasi est quidem magnam voluptate ipsam eos\ntempora quo necessitatibus\ndolor quam autem quasi\nreiciendis et nam sapiente accusantium"
         },
         {
            "postId":1,
            "id":2,
            "name":"quo vero reiciendis velit similique earum",
            "email":"Jayne_Kuhic@sydney.com",
            "body":"est natus enim nihil est dolore omnis voluptatem numquam\net omnis occaecati quod ullam at\nvoluptatem error expedita pariatur\nnihil sint nostrum voluptatem reiciendis et"
         },
         {
            "postId":1,
            "id":3,
            "name":"odio adipisci rerum aut animi",
            "email":"Nikita@garfield.biz",
            "body":"quia molestiae reprehenderit quasi aspernatur\naut expedita occaecati aliquam eveniet laudantium\nomnis quibusdam delectus saepe quia accusamus maiores nam est\ncum et ducimus et vero voluptates excepturi deleniti ratione"
         }
      ]
   }
]

执行此操作的好方法是什么?我以前从未像这样合并过对象。

2 个答案:

答案 0 :(得分:3)

只需使用ES6

const result = postsList.map(post => {
    const comments = commentsList.filter(({ postId }) => postId === post.id);

    return { ...post, comments };
});

答案 1 :(得分:1)

不是最好的解决方案,但它会起作用

var newArr = []
for(let i = 0; i < data.length; i++) {
  for(let j = 0; j < comments.length; j++) {
    if(data[i].id === comments[j].id) {
      data[i].comments = comments[j]
      newArr.push(data[i])
    }
  }
}

console.log(newArr)