GraphQL - Integrasi JQuery

Aplikasi web mengirim dan mengambil data secara asinkron (di latar belakang). AJAX memungkinkan situs web memuat konten ke layar tanpa menyegarkan halaman. jQuery menyediakan beberapa metode untuk fungsionalitas AJAX sehingga memudahkan penggunaan AJAX. Pada bab ini, kita akan mempelajari bagaimana kita dapat mengintegrasikan GraphQL dengan jQuery.

Pertimbangkan aplikasi yang menggunakan arsitektur server klien. Kita dapat membangun halaman web ujung depan yang meminta data dari server GraphQL. Halaman web akan membuat panggilan AJAX menggunakan jQuery ke server GraphQL.

Untuk mengintegrasikan GraphQL dengan JQuery, mari kita periksa header permintaan GraphiQL dan pahami parameter permintaannya.

Memulai hello-worldaplikasi (lihat bab 6 untuk ilustrasi yang relevan). Ketik kueri graphql {salam} di jendela GraphiQL. Klik kanan dan periksa atau tekan (ctrl + shift + I) di chrome untuk membuka tab jaringan seperti yang ditunjukkan di bawah ini -

Dari yang sederhana hello-world Misalnya, kita bisa mengerti itu http method digunakan adalah POST. Sekarang di browser, gulir ke bawah ke bagian header untuk melihat  payload permintaan .

Setelah Anda mengklik view code, Anda akan melihat yang berikut ini di bagian muatan permintaan di chrome.

{"query":"{\n  greeting\n}","variables":null,"operationName":null}

Perhatikan juga URL permintaannya, http://localhost:9000/graphql yang harus dipanggil dari aplikasi klien.

Ilustrasi

Mari kita pahami bagaimana mengintegrasikan GraphQL dengan JQuery menggunakan proses langkah-bijaksana.

Menyiapkan Server

Kami akan belajar mengatur server menggunakan langkah-langkah berikut -

Langkah 1 - Unduh dan Instal Dependensi yang Diperlukan untuk Proyek

Buat folder bernama jquery-server-app. Ubah direktori Anda menjadi jquery-server-app dari terminal. Ikuti langkah 3 hingga 5 yang dijelaskan di bab Pengaturan Lingkungan.

Langkah 2 - Buat Skema

Tambahkan file schema.graphql di folder proyek jquery-server-app dan tambahkan kode berikut -

type Query
{
   greeting: String
   sayHello(name:String!):String
}

File tersebut telah menetapkan dua kueri greeting dan sayHello. Kueri sayHello menerima parameter string dan mengembalikan string lain. Parameter ke fungsi sayHello () tidak null.

Langkah 3 - Buat Resolver

Buat file resolvers.js di folder proyek dan tambahkan kode berikut -

const Query =
{
   greeting: () => 'Hello GraphQL  From TutorialsPoint !!' ,
   sayHello:(root,args,context,info) =>  `Hi ${args.name} GraphQL server says Hello to you!!`
}
module.exports = {Query}

Sini, greeting dan sayHelloadalah dua resolver. Dalam resolver sayHello, nilai yang diteruskan ke parameter nama dapat diakses melalui args. Untuk mengakses fungsi resolver di luar modul, objek Query harus diekspor menggunakanmodule.exports.

Langkah 4 - Jalankan Aplikasi

Buat file server.js. Lihat langkah 8 di Bab Pengaturan Lingkungan. Jalankan perintah npm start di terminal. Server akan aktif dan berjalan pada 9000 port. Di sini, kami menggunakan GraphiQL sebagai klien untuk menguji aplikasi.

Buka browser dan ketik URL-nya http://localhost:9000/graphiql. Ketik kueri berikut di editor -

{
   greeting,
   sayHello(name:"Mohtashim")
}

Tanggapan dari server seperti yang diberikan di bawah ini -

{
   "data": {
      "greeting": "Hello GraphQL From TutorialsPoint !!",
      "sayHello": "Hi Mohtashim GraphQL server says Hello to you!!"
   }
}

Menyiapkan Klien

Karena, kita sudah menyiapkan server, sekarang kita akan belajar cara mengatur klien.

Langkah 1 - Buat folder baru jquery-client-app di luar folder proyek saat ini

Pertama, kita akan membuat folder bernama jquery-client-app di luar folder proyek.

Langkah 2 - Buat Halaman HTML index.html untuk Integrasi jQuery

Kami akan membuat aplikasi klien di jquery dan memanggil kedua metode tersebut. Berikut adalah kode untuk index.html mengajukan. Itu index.html halaman mengirimkan permintaan ke server ketika tombol - Greet dan SayHellodiklik. Kami akan membuat permintaan asinkron menggunakan fungsi $ .ajax ().

<!DOCTYPE html>
<html>
   <head>
      <script src = "https://ajax.googleapis.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
      <script>
         $(document).ready(function() {

            $("#btnSayhello").click(function() {

               const name = $("#txtName").val();
               console.log(name);
               $("#SayhelloDiv").html('loading....');

               $.ajax({url: "http://localhost:9000/graphql",
                  contentType: "application/json",type:'POST',
                  data: JSON.stringify({ query:`{
                     sayHello(name:"${name}")}`
                  }),
                  success: function(result) {
                     console.log(JSON.stringify(result))
                     $("#SayhelloDiv").html("<h1>"+result.data.sayHello +"</h1>");
                  }
               });
            });
            
            $("#btnGreet").click(function() {
               $("#greetingDiv").html('loading....');
               //https://kannan-first-graphql-app.herokuapp.com/graphql
               $.ajax({url: "http://localhost:9000/graphql",
                  contentType: "application/json",
                  type:'POST',
                  data: JSON.stringify({
                     query:`{greeting}`
                  }),
                  success: function(result) {
                     $("#greetingDiv").html("<h1>"+result.data.greeting+"</h1>");
                  }
               });
            });
         });
      </script>
   </head>
   
   <body>
      <h1>Jquery Client </h1>

      <hr/>
      <section>
         <button id = "btnGreet">Greet</button>
         <br/> <br/>
         <div id = "greetingDiv"> </div>
      </section>
      
      <br/> <br/> <br/>
      <hr/>

      <section>
         Enter a name:<input id = "txtName" type = "text" value = "kannan"/>
         <button id = "btnSayhello">SayHello</button>
         <div id = "SayhelloDiv"> </div>
      </section>
   </body>
</html>

Buka file ini di browser dan klik tombol untuk melihat responsnya. Outputnya akan seperti yang diberikan di bawah ini -