FuelPHP - Ajax

AJAX es una tecnología moderna en programación web. Proporciona opciones para enviar y recibir datos en una página web de forma asincrónica, sin actualizar la página. Aprendamos sobre la programación FuelPHP AJAX en este capítulo.

El marco de FuelPHP proporciona opciones para identificar si el tipo de solicitud es AJAX o no. La clase de entrada tiene un método,is_ajax()para este propósito. Si se realiza una solicitud AJAX,Input::is_ajax devuelve el método true, de lo contrario false.

Este método se usa para manejar una solicitud AJAX correctamente en el lado del servidor.

if (Input::is_ajax()) {  
   // Ajax request  
} else {  
   // Normal request  
}

Nosotros podemos usar json_encodepara devolver la respuesta JSON. Podemos combinar estos dos métodos para crear una aplicación web basada en AJAX simple y limpia.

Ejemplo de trabajo

Agreguemos una nueva página, ajax/index en la aplicación del empleado e intente obtener la información del empleado de forma asincrónica.

Step 1 - Cree un nuevo controlador, Controller_Ajax en fuel / app / classes / controller / ajax.php.

<?php  
   class Controller_Ajax extends Controller { 
   }

Step 2- Cree una nueva acción, action_index de la siguiente manera.

<?php  
   class Controller_Ajax extends Controller { 
      public function action_index() { 
         $emps = model_employee::find('all'); 
         $data = array(); 
         $i = 0; 
         
         foreach($emps as $emp) { 
            $data[$i] = array(); 
            $data[$i]['name'] = $emp['name']; 
            $data[$i]['age'] = $emp['age'];  
            $i = $i + 1; 
         }  
         if(\Input::is_ajax()) { 
            echo json_encode($data); 
         } else { 
            return \View::forge("ajax/index"); 
         } 
      } 
   }

Aquí, si la solicitud es AJAX, obtenemos la información del estudiante, la codificamos como JSON y la devolvemos. De lo contrario, simplemente renderizamos la vista correspondiente.

Step 3 - Crear archivo de vista correspondiente, fuel/app/views/ajax/index.php como sigue.

<html>
   <head>
      <script language = "javascript" src = "/assets/js/jquery-3.2.1.min.js"></script>
      
      <style>
         .table { border-collapse: collapse; }
         .table th, td {
            border-bottom: 1px solid #ddd;
            width: 250px;
            text-align: left;
            align: left;
         }
      </style>
   </head>
   
   <body>
      <a id = "loademployee" href = "#">Load employee information</a>
      </br> 
      </br>

      <table class = "table">
         <tbody id = "employee">
         </tbody>
      </table>
      
      <script language = "javascript">
         $(document).ready(function() {
            $("#loademployee").on("click", function(event) {
               $.ajax ({
                  url:        '/ajax/index',
                  type:       'POST',
                  dataType:   'json',
                  async:      true,

                  success: function(data, status) {
                     var e = $('<tr><th>Name</th><th>Age</th></tr>');
                     $('#employee').html('');
                     $('#employee').append(e);
                     
                     for(i = 0; i < data.length; i++) {
                        employee = data[i];
                        var e = $('<tr><td id = "name"></td><td id = "age"></td></tr>');
                        $('#name', e).html(employee['name']);
                        $('#age', e).html(employee['age']);
                        $('#employee').append(e);
                     }
                  },
                  
                  error : function(xhr, textStatus, errorThrown) {
                     alert('Ajax request failed.');
                  }
               });
            });  
         });
      </script>
   </body>
   
</html>

Aquí, hemos creado una etiqueta de anclaje (id: loademployee) para cargar la información del empleado usando la llamada AJAX. La llamada AJAX se realiza mediante JQuery. El evento adjunto a la etiqueta loademployee se activa cuando un usuario hace clic en él. Luego, obtendrá la información del empleado mediante la llamada AJAX y generará el código HTML requerido de forma dinámica.

Step 4 - Ejecuta la aplicación.

Finalmente, ejecute la aplicación, http://localhost:8000/ajax/index y haga clic en la pestaña de anclaje Cargar información del empleado.

Resultado