फ्यूलपीएचपी - अजाक्स

AJAX वेब प्रोग्रामिंग में एक आधुनिक तकनीक है। यह पृष्ठ को ताज़ा किए बिना, वेब पेज में अतुल्यकालिक रूप से डेटा भेजने और प्राप्त करने के विकल्प प्रदान करता है। आइए इस अध्याय में फ्यूलफेप एजेक्स प्रोग्रामिंग के बारे में जानें।

फ्यूलफेप फ्रेमवर्क पहचान के विकल्प प्रदान करता है कि अनुरोध प्रकार AJAX है या नहीं। इनपुट क्लास की एक विधि है,is_ajax()इस काम के लिए। यदि AJAX अनुरोध किया जाता है,Input::is_ajax विधि रिटर्न true, अन्यथा false

इस विधि का उपयोग सर्वर साइड पर AJAX अनुरोध को ठीक से संभालने के लिए किया जाता है।

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

हम प्रयोग कर सकते हैं json_encodeJSON प्रतिक्रिया वापस करने के लिए। हम एक सरल और साफ AJAX आधारित वेब एप्लिकेशन बनाने के लिए इन दो तरीकों को जोड़ सकते हैं।

काम करने का उदाहरण

हमें एक नया पृष्ठ जोड़ने के लिए, ajax/index कर्मचारी के आवेदन में और अतुल्यकालिक रूप से कर्मचारी जानकारी प्राप्त करने का प्रयास करें।

Step 1 - फ्यूल / ऐप / क्लासेस / कंट्रोलर / ajax.php पर एक नया कंट्रोलर, कंट्रोलर_जैक्स बनाएं।

<?php  
   class Controller_Ajax extends Controller { 
   }

Step 2- निम्नानुसार एक नया एक्शन, एक्शन_इंडेक्स बनाएं ।

<?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"); 
         } 
      } 
   }

यहां, यदि अनुरोध AJAX है, तो हम छात्र जानकारी प्राप्त करते हैं, इसे JSON के रूप में एन्कोड करते हैं, और इसे वापस करते हैं। अन्यथा, हम सिर्फ इसी दृश्य को प्रस्तुत करते हैं।

Step 3 - संबंधित दृश्य फ़ाइल बनाएं, fuel/app/views/ajax/index.php निम्नलिखित नुसार।

<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>

यहां, हमने AJAX कॉल का उपयोग करके कर्मचारी जानकारी लोड करने के लिए एक एंकर टैग (id: loademployee) बनाया है। AJAX कॉल JQuery का उपयोग करके किया जाता है। जब उपयोगकर्ता क्लिक करता है, तो लोड-लोड कर्मचारी टैग से जुड़ी घटना सक्रिय हो जाती है। फिर, यह AJAX कॉल का उपयोग करके कर्मचारी जानकारी प्राप्त करेगा और आवश्यक HTML कोड गतिशील रूप से उत्पन्न करेगा।

Step 4 - एप्लिकेशन चलाएँ।

अंत में, एप्लिकेशन चलाएँ, http://localhost:8000/ajax/index और लोड कर्मचारी सूचना एंकर टैब पर क्लिक करें।

परिणाम