JavaScript AJAX (Asynchronous JavaScript and XML) is a technique used to exchange data with a server without requiring the entire page to be refreshed. This allows for dynamic and asynchronous communication between the client and server. In this guide, we'll introduce JavaScript AJAX and the XMLHttpRequest object, and provide sample code to demonstrate its usage.


XMLHttpRequest Object


The XMLHttpRequest object is the foundation of AJAX in JavaScript. It allows you to make HTTP requests to fetch or send data to a server without reloading the entire page. Here's a basic example of how to create an XMLHttpRequest object:


const xhr = new XMLHttpRequest();

Making a GET Request


Let's make a simple GET request to retrieve data from a server and update the page. Here's an example:


const xhr = new XMLHttpRequest();
xhr.open('GET', 'https://jsonplaceholder.typicode.com/posts/1', true);
xhr.onload = function() {
if (xhr.status === 200) {
const responseData = JSON.parse(xhr.responseText);
console.log('Data:', responseData);
}
};
xhr.send();

Making a POST Request


You can also make POST requests to send data to the server. Here's a sample code for a POST request:


const xhr = new XMLHttpRequest();
xhr.open('POST', 'https://jsonplaceholder.typicode.com/posts', true);
xhr.setRequestHeader('Content-Type', 'application/json');
const postData = JSON.stringify({
title: 'New Post',
body: 'This is the post body.',
userId: 1
});
xhr.onload = function() {
if (xhr.status === 201) {
const responseData = JSON.parse(xhr.responseText);
console.log('Created Post:', responseData);
}
};
xhr.send(postData);

Handling Errors


It's essential to handle errors when working with XMLHttpRequest. You can do this by adding error-handling logic to the request:


const xhr = new XMLHttpRequest();
xhr.open('GET', 'https://jsonplaceholder.typicode.com/invalid-url', true);
xhr.onload = function() {
if (xhr.status === 200) {
const responseData = JSON.parse(xhr.responseText);
console.log('Data:', responseData);
} else {
console.error('Request failed with status:', xhr.status);
}
};
xhr.onerror = function() {
console.error('Request error occurred.');
};
xhr.send();

Conclusion


JavaScript AJAX and the XMLHttpRequest object are fundamental tools for building interactive and dynamic web applications. They allow you to fetch and send data to and from servers without page reloads, providing a seamless user experience.


Explore JavaScript AJAX further to build interactive web applications with real-time data exchange between the client and server.