Symfony - Kontrol Ajax

AJAX adalah teknologi modern dalam pemrograman web. Ini memberikan opsi untuk mengirim dan menerima data di halaman web secara asinkron, tanpa menyegarkan halaman. Mari kita pelajari pemrograman Symfony AJAX di bab ini.

Kerangka kerja Symfony menyediakan opsi untuk mengidentifikasi apakah jenis permintaan adalah AJAX atau tidak. Kelas permintaan komponen Symfony HttpFoundation memiliki metode, isXmlHttpRequest () untuk tujuan ini. Jika permintaan AJAX dibuat, metode isXmlHttpRequest () objek permintaan saat ini mengembalikan nilai benar, jika tidak salah.

Metode ini digunakan untuk menangani permintaan AJAX dengan benar di sisi server.

if ($request->isXmlHttpRequest()) {  
   // Ajax request  
} else {  
   // Normal request  
}

Symfony juga menyediakan kelas Respon berbasis JSON, JsonResponse untuk membuat respon dalam format JSON. Kita dapat menggabungkan kedua metode ini untuk membuat aplikasi web berbasis AJAX yang sederhana dan bersih.

AJAX - Contoh Kerja

Mari kita tambahkan halaman baru, student/ajax dalam aplikasi siswa dan mencoba untuk mengambil informasi siswa secara asinkron.

Step 1 - Tambahkan metode ajaxAction di StudentController (src / AppBundle / Controller / StudentController.php).

/** 
   * @Route("/student/ajax") 
*/ 
public function ajaxAction(Request $request) {  
   $students = $this->getDoctrine() 
      ->getRepository('AppBundle:Student') 
      ->findAll();  
      
   if ($request->isXmlHttpRequest() || $request->query->get('showJson') == 1) {  
      $jsonData = array();  
      $idx = 0;  
      foreach($students as $student) {  
         $temp = array(
            'name' => $student->getName(),  
            'address' => $student->getAddress(),  
         );   
         $jsonData[$idx++] = $temp;  
      } 
      return new JsonResponse($jsonData); 
   } else { 
      return $this->render('student/ajax.html.twig'); 
   } 
}

Di sini, jika permintaannya adalah AJAX, kami mengambil informasi siswa, menyandikannya sebagai JSON dan mengembalikannya menggunakan JsonResponseobyek. Jika tidak, kami hanya membuat tampilan yang sesuai.

Step 2 - Buat file tampilan ajax.html.twig dalam direktori tampilan Mahasiswa, app/Resources/views/student/ dan tambahkan kode berikut.

{% extends 'base.html.twig' %} 
{% block javascripts %} 
   <script language = "javascript" 
      src = "https://code.jquery.com/jquery-2.2.4.min.js"></script> 
   
   <script language = "javascript">  
      $(document).ready(function(){   
         $("#loadstudent").on("click", function(event){  
            $.ajax({  
               url:        '/student/ajax',  
               type:       'POST',   
               dataType:   'json',  
               async:      true,  
               
               success: function(data, status) {  
                  var e = $('<tr><th>Name</th><th>Address</th></tr>');  
                  $('#student').html('');  
                  $('#student').append(e);  
                  
                  for(i = 0; i < data.length; i++) {  
                     student = data[i];  
                     var e = $('<tr><td id = "name"></td><td id = "address"></td></tr>');
                     
                     $('#name', e).html(student['name']);  
                     $('#address', e).html(student['address']);  
                     $('#student').append(e);  
                  }  
               },  
               error : function(xhr, textStatus, errorThrown) {  
                  alert('Ajax request failed.');  
               }  
            });  
         });  
      });  
   </script> 
{% endblock %}  

{% block stylesheets %} 
   <style> 
      .table { border-collapse: collapse; } 
      .table th, td { 
         border-bottom: 1px solid #ddd; 
         width: 250px; 
         text-align: left; 
         align: left; 
      } 
   </style> 
{% endblock %} 

{% block body %} 
   <a id = "loadstudent" href = "#">Load student information</a>  
   </br> 
   </br>  
   
   <table class = "table">  
      <tbody id = "student"></tbody>  
   </table>     
{% endblock %}

Di sini, kami telah membuat tag jangkar (id: loadstudent) untuk memuat informasi siswa menggunakan panggilan AJAX. Panggilan AJAX dilakukan menggunakan JQuery. Peristiwa yang dilampirkan ke tag loadstudent aktif ketika pengguna mengkliknya. Kemudian, itu akan mengambil informasi siswa menggunakan panggilan AJAX dan menghasilkan kode HTML yang diperlukan secara dinamis.

Step 3- Terakhir, jalankan aplikasinya, http://localhost:8000/student/ajax dan klik tab Muat jangkar informasi siswa.

Hasil: Halaman Awal

Hasil: Halaman dengan Informasi Siswa