最新消息:雨落星辰是一个专注网站SEO优化、网站SEO诊断、搜索引擎研究、网络营销推广、网站策划运营及站长类的自媒体原创博客

javascript - How to flatten a promise.all response - Stack Overflow

programmeradmin1浏览0评论

I have a list of products and for each product im making an api call to get the products subscription.

   const subscriptions = await Promise.all(products.flatMap((p: any) => {
        const { username, password } = p.credentials;
        return GetSubscription(username, password);
    }));
    console.log(subscriptions);

Actual:

[ [ {}, {}, {}, ] ]

now you can see i have a double nested array here and i don't need the outer array, how can i flatten this array, i assumed using flatMap here might help me but it did not.

Expected:

[ {}, {}, {}, ]

Ofcourse i could simply do subscriptions[0] but im trying to avoid that if possible.

I have a list of products and for each product im making an api call to get the products subscription.

   const subscriptions = await Promise.all(products.flatMap((p: any) => {
        const { username, password } = p.credentials;
        return GetSubscription(username, password);
    }));
    console.log(subscriptions);

Actual:

[ [ {}, {}, {}, ] ]

now you can see i have a double nested array here and i don't need the outer array, how can i flatten this array, i assumed using flatMap here might help me but it did not.

Expected:

[ {}, {}, {}, ]

Ofcourse i could simply do subscriptions[0] but im trying to avoid that if possible.

Share Improve this question asked Jan 27, 2020 at 10:36 KayKay 19.7k72 gold badges184 silver badges301 bronze badges 2
  • 3 Array.prototype.flat() - developer.mozilla/en-US/docs/Web/JavaScript/Reference/… – Bloatlord Commented Jan 27, 2020 at 10:38
  • ah the simple .flat does not make my api call GetSubscription so it did not work – Kay Commented Jan 27, 2020 at 10:55
Add a ment  | 

3 Answers 3

Reset to default 8

Use the spread operator

async function func() {
  return 'A';
}

(async() => {
  const [...ret] = await Promise.all([
    func(),
    func(),
    func(),
  ]);

  console.log(ret);
})();

Or

async function func() {
  return 'A';
}

(async() => {
  const ret = await Promise.all([
    func(),
    func(),
    func(),
  ]);

  console.log(ret.reduce((tmp, x) => [...tmp, x], []));
})();


As you said in your ment, specifying ES2019 in your tsconfig, you can use Array.flat :

async function func() {
  return 'A';
}

(async() => {
  const ret = await Promise.all([
    func(),
    func(),
    func(),
  ]);

  console.log(ret.flat());
})();

This should help you.

const input = [[{}, {}, {}], [{"hi": "bye"}]];


console.log(input.flat());

Array.flatMap() is the same as Array.map().flat(). So await Promise.all(Array.map().flat()) will be applied to the result of flat. When the map callback is asynchronous you need to resolve the result of map before calling flat. In that case you would need to use (await Promise.all(Array.map())).flat().

发布评论

评论列表(0)

  1. 暂无评论