avatar

for await...of

The for await...of statement creates a loop iterating over async iterable objects as well as sync iterables.

function* generator() {
  yield 1
  yield Promise.resolve(2)
  yield 3
}

;(async () => {
  for await (const num of generator()) {
    console.log(num)
  }
})()
// 1, 2, 3

// for-of
for (const numOrPromise of generator()) {
  console.log(numOrPromise)
}
// 1, Promise { 2 }, 3