Skip to content

Instantly share code, notes, and snippets.

@DavidWells
Forked from Atinux/async-foreach.js
Created October 22, 2018 04:10
Show Gist options
  • Star 1 You must be signed in to star a gist
  • Fork 0 You must be signed in to fork a gist
  • Save DavidWells/a0819be9f4041351a704bfc8360f6335 to your computer and use it in GitHub Desktop.
Save DavidWells/a0819be9f4041351a704bfc8360f6335 to your computer and use it in GitHub Desktop.
JavaScript: async/await with forEach()
const waitFor = (ms) => new Promise(r => setTimeout(r, ms))
const asyncForEach = (array, callback) => {
for (let index = 0; index < array.length; index++) {
await callback(array[index], index, array)
}
}
const start = async () => {
await asyncForEach([1, 2, 3], async (num) => {
await waitFor(50)
console.log(num)
})
console.log('Done')
}
start()
@DavidWells
Copy link
Author

DavidWells commented Oct 22, 2018

const waitFor = (ms) => new Promise(r => setTimeout(r, ms))

async function asyncForEach(array, callback) {
  for (let index = 0; index < array.length; index++) {
    await callback(array[index], index, array)
  }
}

const start = async () => {
  await asyncForEach([1, 2, 3], async (num) => {
    await waitFor(50)
    console.log(num)
  })
  console.log('Done')
}
start()

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment