DEV Community

Cover image for Mastering Asynchronous Programming in JavaScript
akanni hannah
akanni hannah

Posted on

1

Mastering Asynchronous Programming in JavaScript

Synchronous programming is a crucial concept in JavaScript, enabling you to handle operations like API calls, file reading, and timers without blocking the main thread. If you're new to the concept or want to solidify your understanding, this post is for you!

What is Asynchronous Programming?

In synchronous programming, tasks are executed one after the other, which can lead to inefficient use of resources, especially when dealing with operations that take time (like network requests). Asynchronous programming allows your code to run while waiting for these operations to complete, improving performance and responsiveness.

Key Concepts

  1. Callbacks
  2. Promises
  3. Async/Await

Let’s break down each of these concepts.

1. Callbacks

A callback is a function that is passed as an argument to another function and is executed once a task is completed. While simple, callbacks can lead to "callback hell" when you have nested functions.

function fetchData(callback) {
    setTimeout(() => {
        const data = "Data received!";
        callback(data);
    }, 1000);
}

fetchData((data) => {
    console.log(data); // Output: Data received!
});

Enter fullscreen mode Exit fullscreen mode

**2. Promises
**Promises provide a cleaner alternative to callbacks. A promise represents a value that may be available now, or in the future, or never. It can be in one of three states: pending, fulfilled, or rejected.

Here’s how to use promises:

function fetchData() {
    return new Promise((resolve, reject) => {
        setTimeout(() => {
            const data = "Data received!";
            resolve(data); // or reject(error);
        }, 1000);
    });
}

fetchData()
    .then((data) => {
        console.log(data); // Output: Data received!
    })
    .catch((error) => {
        console.error(error);
    });

Enter fullscreen mode Exit fullscreen mode

**3. Async/Await

Introduced in ES2017, async and await provide a more readable way to work with promises. You define a function as async, and within that function, you can use await to pause execution until a promise is resolved.

async function fetchData() {
    return new Promise((resolve) => {
        setTimeout(() => {
            resolve("Data received!");
        }, 1000);
    });
}

async function getData() {
    try {
        const data = await fetchData();
        console.log(data); // Output: Data received!
    } catch (error) {
        console.error(error);
    }
}

getData();

Enter fullscreen mode Exit fullscreen mode

Error Handling

When working with asynchronous code, proper error handling is essential. With promises, you can use.catch(), and with async/await, you can use try/catch blocks.

Real-World Example

Let’s put this into context. Here’s an example of fetching data from an API using fetch, which returns a promise:

async function fetchUserData(userId) {
    try {
        const response = await fetch(`https://jsonplaceholder.typicode.com/users/${userId}`);
        if (!response.ok) {
            throw new Error("Network response was not ok");
        }
        const userData = await response.json();
        console.log(userData);
    } catch (error) {
        console.error("Fetch error:", error);
    }
}

fetchUserData(1);

Enter fullscreen mode Exit fullscreen mode

Conclusion

Asynchronous programming in JavaScript allows you to write efficient and responsive code. By mastering callbacks, promises, and async/await, you’ll be well-equipped to handle asynchronous operations gracefully.

SurveyJS custom survey software

JavaScript UI Libraries for Surveys and Forms

SurveyJS lets you build a JSON-based form management system that integrates with any backend, giving you full control over your data and no user limits. Includes support for custom question types, skip logic, integrated CCS editor, PDF export, real-time analytics & more.

Learn more

Top comments (1)

Collapse
 
ravavyr profile image
Ravavyr

Stick with Async/Await and don't use try/catch but rather code to capture the errors and display them within the code logic so your user isn't left scratching their head while your console screams "it broke, please refresh!" and they never see it.

Billboard image

The Next Generation Developer Platform

Coherence is the first Platform-as-a-Service you can control. Unlike "black-box" platforms that are opinionated about the infra you can deploy, Coherence is powered by CNC, the open-source IaC framework, which offers limitless customization.

Learn more

👋 Kindness is contagious

Please leave a ❤️ or a friendly comment on this post if you found it helpful!

Okay