Async/Await Pair in Asynchronous Code

Learn to revolutionize the way we deal with asynchronous code using async/await.

async/await

Promises are a quantum leap ahead of callbacks. They allow us to write clean and readable asynchronous code and provide a set of safeguards that can only be achieved with boilerplate code when working with callback-based asynchronous code. However, promises are still suboptimal when it comes to writing sequential asynchronous code. The Promise chain is indeed much better than having callback hell, but still, we have to invoke a then() function and create a new function for each task in the chain. This is still too much for a control flow that’s definitely the most commonly used in everyday programming. JavaScript needed a proper way to deal with the comprehensive asynchronous sequential execution flow, and the answer arrived with the introduction in the ECMAScript standard of async functions and the await expression (async/await for short).

The async/await dichotomy allows us to write functions that appear to block at each asynchronous operation, waiting for the results before continuing with the following statement. As we’ll see, any asynchronous code using async/await has a readability comparable to traditional synchronous code.

Today, async/await is the recommended construct for dealing with asynchronous code in both Node.js and JavaScript. However, async/await doesn’t replace all that we’ve learned so far about asynchronous control flow patterns; on the contrary, as we’ll see, async/await heavily relies on promises.

Async functions and the await expression

An async function is a special type of function in which it’s possible to use the await expression to “pause” the execution on a given Promise until it resolves. Let’s consider a simple example and use the delay() function we implemented in the “Creating a promise” section. The Promise returned by delay() resolves with the current date as the value after the given number of milliseconds. Here’s how we can use this function with the async/await pair:

Get hands-on with 1300+ tech skills courses.