Contoh Dasar Ajax Menggunakan XMLHttpRequest - Mengenal Dasar Ajax Menggunakan XMLHttpRequest

Contoh Dasar Ajax Menggunakan XMLHttpRequest


XMLHttpRequest atau disingkat XHR adalah objek yang tersedia pada browser yang digunakan untuk membuat HTTP Requests menggunakan JavaScript. Karena namanya kita mungkin menganggap  bahwa XHR ini hanya mendukung format data XML, namun pada kenyataannya saat ini XHR bisa  digunakan oleh banyak format, bukan hanya XML.

Meskipun saat ini terdapat cara yang lebih modern yakni menggunakan fetch, tetapi masih ada kok beberapa developer yang masih menggunakan XHR dalam melakukan HTTP Request. Alasannya karena ada atau masih dukungan browser tua atau suatu fitur yang tidak bisa fetch lakukan seperti tracking upload progress.

Basic Usage

XMLHttpRequest bisa berjalan secara synchronous serta asynchronous. Akan tetapi kebanyakan kasus HTTP Request sebaiknya asynchronous.
berikut ini Contoh penggunaan dasar dari XMLHttpRequest adalah seperti dibawah ini:
202003132318522fefb326486e99f9449b3ea0b5d8cb31.png
Langkah pertama untuk menggunakan XMLHttpRequest yakni dengan membuat instance baru dari objek XMLHttpRequest seperti  dibawah ini:

  1. const xhr = new XMLHttpRequest();


Kemudian pada instance dari objek tersebut (xhr) kita harus tentukan callback function ketika request berhasil (onload) dan ketika request gagal (onerror).

  1. xhr.onload = function () {

  2. console.log(this.responseText);

  3. }

  4. xhr.onerror = function () {

  5. console.log("Ups something error")

  6. }


pada callback function tersebut, value atau nilai dari this merupakan XHR objek. Sehingga this.responseText akan mempunyai nilai response (dalam bentuk text) dari server. perlu diingat karena pada callback function tersebut nilai this merupakan XHR objek, kita tidak bisa menggunakan gaya arrow function dalam menuliskan callback functionnya.

  1. xhr.onload = () => {

  2.     // akan menyebabkan error, karena arrow function tidak memiliki this.

  3.     console.log(this.responseText);

  4. }


Selanjutnya kita harus tentukan HTTP Method dan URL yang dituju dengan menggunakan method .open()

  1. xhr.open("GET", "https://api-to-call.com/endpoint");


Nah, langkah terakhir adalah mengirimkan request yang telah kita konfigurasi di atas menggunakan method .send().

  1. xhr.send();


Sehingga seluruh kode dalam penggunaan dasar dari XMLHttpRequest  ini dengan contoh target url berikut https://web-server-book-dicoding.appspot.com/list adalah seperti dibawah ini:

  1. const xhr = new XMLHttpRequest();

  2.  

  3. xhr.onload = function () {

  4.  console.log(this.responseText)

  5. }

  6. xhr.onerror = function () {

  7.  console.log("Ups something error")

  8. }

  9.  

  10. xhr.open("GET", "https://web-server-book-dicoding.appspot.com/list");

  11. xhr.send();


Coba Anda copy dan paste code di atas dan jalankan code pada console devTools. Jika request berhasil, Anda akan melihat dan mendapat data dalam bentuk JSON String. Data tersebut dapat Anda olah menjadi JavaScript objek dengan mengubahnya menggunakan method JSON.parse().

  1. JSON.parse(this.responseText)


Anda juga bisa menjajal atau mencoba untuk menjalankan potongan kode di atas pada repl.it melalui tautan berikut ini: https://repl.it/@dicodingacademy/163-06-AJAX-XHR-basic?lite=true

Header and Body Request using XHR

tadi kita sudah belajar bagaimana cara membuat dan menggunakan dasar XMLHttpRequest dalam membuat sebuah GET Request. Lantas bagaimana jika kita ingin mempergunakan method POST dan menetapkan properti pada Header ? Lantas bagaimana caranya guna mengirimkan data pada body HTTP Request? Mari kita bahas permasalahan tersebut satu per satu.

Set Header Property

Dalam menggunakan Web API tidak selalu kita hanya menggunakan GET request saja, terutama ketika request yang kita inginkan, yang mana ini bertujuan mengubah atau menambahkan data. Web API umumnya meminta kita untuk melaksanakannya dengan method POST atau PUT. Tak jarang juga Web API meminta kita untuk menetapkan properti tertentu pada request header guna menunjukkan credential yang kita punyai. Request tersebut sudah pernah kita coba yah Bos Qu menggunakan Postman. akan tetapi bagaimana ya caranya jika menggunakan XHR?
Untuk menetapkan properti pada request header, Anda bisa menggunakan method setRequestHeader() pada instance XMLHttpRequest setelah menetapkan method .open(). Method tersebut menerima dua parameter. Parameter pertama adalah nama properti dan parameter, yang kedua merupakan nilai yang akan ditetapkan pada properti tersebut. Sehingga untuk menetapkan properti Content-Type dengan value application/json pada request kita bisa melakukannya dengan cara seperti berikut ini:

  1. const xhr = new XMLHttpRequest();

  2.  

  3. xhr.onload = function() {

  4.  console.log(this.responseText);

  5. }

  6.  

  7. xhr.onerror = function() {

  8.  console.log("Ups something error");

  9. }

  10.  

  11. xhr.open("POST", "https://web-server-book-dicoding.appspot.com/add");

  12.  

  13. // menambahkan properti pada header request

  14. xhr.setRequestHeader("Content-Type", "application/json");


Kita bisa juga menetapkan properti pada request header sebanyak yang kita perlukan atau inginkan.

  1. const xhr = new XMLHttpRequest();

  2.  

  3. xhr.onload = function() {

  4.  console.log(this.responseText);

  5. }

  6.  

  7. xhr.onerror = function() {

  8.  console.log("Ups something error");

  9. }

  10.  

  11. xhr.open("POST", "https://web-server-book-dicoding.appspot.com/add");

  12.  

  13. // menambahkan properti pada header request

  14. xhr.setRequestHeader("Content-Type", "application/json");

  15. xhr.setRequestHeader("X-Auth-Token", "12345")


Lumayan mudah bukan Bos Qu?

Set Data to Body Request

Lalu guna menetapkan data pada body request, kita perlu melakukannya pada method .send() dari instance XMLHttpRequest. Semisal guna mengirimkan data JSON String pada body request, begini caranya sebagai berikut: 

  1. const xhr = new XMLHttpRequest();

  2.  

  3. xhr.onload = function() {

  4.  console.log(this.responseText);

  5. }

  6.  

  7. xhr.onerror = function() {

  8.  console.log("Ups something error");

  9. }

  10.  

  11. xhr.open("POST", "https://web-server-book-dicoding.appspot.com/add");

  12.  

  13. // menambahkan properti pada header request

  14. xhr.setRequestHeader("Content-Type", "application/json");

  15. xhr.setRequestHeader("X-Auth-Token", "12345")

  16.  

  17. const book = {

  18.  id: 10,

  19.  title: "Edensor",

  20.  author: "Andrea Hirata"

  21. }

  22.  

  23. xhr.send(JSON.stringify(book));


Sebenarnya tidak hanya JSON format yang bisa dikirimkan melalui body, namun apa yang dilansir pada situs MDN menyebutkan bahwa kita juga dapat mengirimkan dokumen yang sudah ter-serialized sebelum dikirim, atau data lain yang sudah terdaftar pada Fetch spec seperti BlobBufferSourceFormDataURLSeachParamReadableStream atau juga USVString object.
Contoh daripada kode di atas bisa Anda akses atau temukan pada tautan link berikut https://repl.it/@dicodingacademy/163-06-AJAX-XHR-Header-and-Body?lite=true. Anda bisa mencoba mellakukan POST Request dengan menjalankan potongan kode tersebut.
Hasil Akhir Cek link berikut :
https://github.com/dicodingacademy/a163-bfwd-labs/tree/302-dicoding-books-xhr

Terimakasih Semoga bermanfaat !!


Baca Juga : mengenal JSON - Apa Itu JSON?





About the Author

Rudi Kilam merupakan seorang pelajar yang mempunyai keinginan dan memiliki minat menulis sebuah artikel terkait dengan pengetahuan umum, IT, kesehatan, ekonomi, sosiologi, pembudidayaan dan lain sebagainya.
Cookie Consent
We serve cookies on this site to analyze traffic, remember your preferences, and optimize your experience.
Oops!
It seems there is something wrong with your internet connection. Please connect to the internet and start browsing again.
AdBlock Detected!
We have detected that you are using adblocking plugin in your browser.
The revenue we earn by the advertisements is used to manage this website, we request you to whitelist our website in your adblocking plugin.
Site is Blocked
Sorry! This site is not available in your country.