Symfony-Ajax 제어

AJAX는 웹 프로그래밍의 최신 기술입니다. 페이지를 새로 고치지 않고 웹 페이지에서 비동기 적으로 데이터를 보내고받는 옵션을 제공합니다. 이 장에서 Symfony AJAX 프로그래밍을 배우도록하겠습니다.

Symfony 프레임 워크는 요청 유형이 AJAX인지 여부를 식별하는 옵션을 제공합니다. Symfony HttpFoundation 컴포넌트의 요청 클래스에는이를 위해 isXmlHttpRequest () 메소드가 있습니다. AJAX 요청이 이루어지면 현재 요청 객체의 isXmlHttpRequest () 메서드가 true를 반환하고 그렇지 않으면 false를 반환합니다.

이 메소드는 서버 측에서 AJAX 요청을 적절하게 처리하는 데 사용됩니다.

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

Symfony는 또한 JSON 형식으로 응답을 생성하기 위해 JSON 기반 Response 클래스 인 JsonResponse를 제공합니다. 이 두 가지 방법을 결합하여 간단하고 깨끗한 AJAX 기반 웹 애플리케이션을 만들 수 있습니다.

AJAX-작업 예

새 페이지를 추가하겠습니다. student/ajax 학생 응용 프로그램에서 학생 정보를 비동기 적으로 가져 오십시오.

Step 1 − StudentController (src / AppBundle / Controller / StudentController.php)에 ajaxAction 메소드를 추가합니다.

/** 
   * @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'); 
   } 
}

여기에서 요청이 AJAX이면 학생 정보를 가져 와서 JSON으로 인코딩하고 다음을 사용하여 반환합니다. JsonResponse목적. 그렇지 않으면 해당 뷰를 렌더링합니다.

Step 2 −보기 파일 생성 ajax.html.twig 학생보기 디렉토리에서 app/Resources/views/student/ 다음 코드를 추가하십시오.

{% 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 %}

여기에서는 AJAX 호출을 사용하여 학생 정보를로드하기위한 앵커 태그 (id : loadstudent)를 생성했습니다. AJAX 호출은 JQuery를 사용하여 수행됩니다. loadstudent 태그에 첨부 된 이벤트는 사용자가 클릭하면 활성화됩니다. 그런 다음 AJAX 호출을 사용하여 학생 정보를 가져오고 필요한 HTML 코드를 동적으로 생성합니다.

Step 3− 마지막으로 응용 프로그램을 실행하고 http://localhost:8000/student/ajax 학생 정보로드 앵커 탭을 클릭합니다.

결과 : 초기 페이지

결과 : 학생 정보가있는 페이지