Welcome to OGeek Q&A Community for programmer and developer-Open, Learning and Share
Welcome To Ask or Share your Answers For Others

Categories

0 votes
306 views
in Technique[技术] by (71.8m points)

arrays - How to delete subarrays but keep their contents in Javascript?

I have the following array of objects:

const pages = [
  {
    posts: {
      pageInfo: { 
        hasNextPage: true 
      },
      edges: [
        { id: 1 },
        { id: 2 }
      ]
    }
  },
  {
    posts: {
      pageInfo: { 
        hasNextPage: true 
      },
      edges: [
        { id: 3 },
        { id: 4 }
      ]
    }
  },
]

I need to keep only the content of the edges subarrays, like this:

const postsOnly = [
  { id: 1 },
  { id: 2 },
  { id: 3 },
  { id: 4 }
]

Closest I've come is:

const postsOnly = pages.map( ( { posts } ) =>  posts.edges ) 

But this leaves me with a subarray for every original posts object, like this:

const postsOnly = [
  [
    { id: 1 },
    { id: 2 }
  ],
  [
    { id: 3 },
    { id: 4 }
  ]
]

How can I delete these subarrays but keep their contents?


与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…
Welcome To Ask or Share your Answers For Others

1 Reply

0 votes
by (71.8m points)

You can either use map(...).flat() or flatMap(...) to flatten the result

const pages = [
  {
    posts: {
      pageInfo: { 
        hasNextPage: true 
      },
      edges: [
        { id: 1 },
        { id: 2 }
      ]
    }
  },
  {
    posts: {
      pageInfo: { 
        hasNextPage: true 
      },
      edges: [
        { id: 3 },
        { id: 4 }
      ]
    }
  },
];

const postsOnly = pages.map( ( { posts } ) =>  posts.edges );
const postsOnly2 = pages.flatMap( ( { posts } ) =>  posts.edges );
const postsOnly3 = pages.map( ( { posts } ) =>  posts.edges ).flat();

console.log(postsOnly);
/* Output: 
[ [ { id: 1 }, { id: 2 } ], [ { id: 3 }, { id: 4 } ] ]
*/
console.log(postsOnly2);
/* Output:
[ { id: 1 }, { id: 2 }, { id: 3 }, { id: 4 } ]
*/
console.log(postsOnly3);
/* Output:
[ { id: 1 }, { id: 2 }, { id: 3 }, { id: 4 } ]
*/

与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…
OGeek|极客中国-欢迎来到极客的世界,一个免费开放的程序员编程交流平台!开放,进步,分享!让技术改变生活,让极客改变未来! Welcome to OGeek Q&A Community for programmer and developer-Open, Learning and Share
Click Here to Ask a Question

...