Async/Await is part of the ES2017 specification and provides a more streamlined syntax for dealing with promises, leading to cleaner, easier-to-read code.
Async/Await uses JavaScript fetch API (which returns promises) for making HTTP requests.
The async and await keywords enable asynchronous, promise-based behavior to be written in a cleaner style, avoiding the need for explicitly chaining promises. These keywords make the asynchronous code look and behave like synchronous code.
Async/Await in JavaScript, which is often used with the Fetch API for making HTTP requests, has several advantages over traditional AJAX techniques:
We'll use the same example, but with async/await framework instead of ajax:
<!DOCTYPE html> <html> <body> <div id="data"></div> <script> async function fetchData() { try { const response = await fetch('https://api.github.com/users'); const data = await response.json(); data.forEach(user => { const div = document.getElementById('data'); div.innerHTML += ` <img src="${user.avatar_url}" alt="${user.login}'s avatar" width="100"><br> Login: ${user.login}<br> ID: ${user.id}<br> Node ID: ${user.node_id}<br> Avatar URL: ${user.avatar_url}<br> Gravatar ID: ${user.gravatar_id}<br> URL: ${user.url}<br> HTML URL: ${user.html_url}<br> Followers URL: ${user.followers_url}<br> Following URL: ${user.following_url}<br> Gists URL: ${user.gists_url}<br> Starred URL: ${user.starred_url}<br> Subscriptions URL: ${user.subscriptions_url}<br> Organizations URL: ${user.organizations_url}<br> Repos URL: ${user.repos_url}<br> Events URL: ${user.events_url}<br> Received Events URL: ${user.received_events_url}<br> Type: ${user.type}<br> Site Admin: ${user.site_admin}<br> <hr> `; }); } catch (error) { console.error('Error:', error); } } fetchData(); </script> </body> </html>