Learning JavaScript? Download my free JavaScript Handbook 🔥

You want to execute an async function inside a map() call, to perform an operation on every element of the array, and get the results back.

How can you do so?

This is the correct syntax:

const list = [] //...an array filled with values

const functionWithPromise = item => { //a function that returns a promise
  return Promise.resolve('ok')

const anAsyncFunction = async item => {
  return await functionWithPromise(item)

const getData = async () => {
  return await Promise.all(list.map(item => anAsyncFunction(item)))

getData().then(data => {

The main thing to notice is the use of Promise.all(), which resolves when all it’s promises are resolved.

list.map() returns a list of promises, so in result we’ll get the value when everything we ran is resolved.

Remember, we must wrap any code that calls await in an async function.

See the promises article for more on promises, and the async/await guide.

Found a typo or problem? Edit this page