ज़ेंड फ्रेमवर्क - अजाक्स

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

Json घटक स्थापित करें

Zend json घटक का उपयोग कर स्थापित किया जा सकता है Composer नीचे दिए गए आदेश के रूप में -

composer require zendframework/zend-json

संकल्पना

Zend फ्रेमवर्क AJAX सक्षम वेब एप्लिकेशन को आसानी से लिखने के लिए दो तरीके प्रदान करता है। वे इस प्रकार हैं -

  • isXmlHttpRequest() में विधि Requestऑब्जेक्ट - यदि AJAX अनुरोध किया जाता है, तो अनुरोध ऑब्जेक्ट का isXmlHttpRequest () विधि सही है, अन्यथा गलत है। इस विधि का उपयोग सर्वर साइड में AJAX अनुरोध को ठीक से संभालने के लिए किया जाता है।

if ($request->isXmlHttpRequest()) { 
   // Ajax request 
} else { 
   // Normal request 
}
  • ज़ेंड / दृश्य / मॉडल / JsonModel - द JsonModel के लिए एक विकल्प है ViewModelAJAX और REST API परिदृश्यों के लिए विशेष रूप से उपयोग किया जाना है। JsonModel के साथJsonStrategy (मॉड्यूल के व्यू मैनेजर ब्लॉक में कॉन्फ़िगर किया जाना है) मॉडल डेटा को इनकोड करता है Json और इसे विचारों (phtml) के बजाय प्रतिक्रिया के रूप में देता है।

AJAX - कार्य उदाहरण

हमें एक नया AJAX पेज जोड़ें, ajaxट्यूटोरियल मॉड्यूल में और अतुल्यकालिक रूप से पुस्तक की जानकारी प्राप्त करें। ऐसा करने के लिए, हमें निम्नलिखित चरणों का पालन करना चाहिए।

चरण 1: मॉड्यूल कॉन्फ़िगरेशन में JsonStrategy जोड़ें

ट्यूटोरियल मॉड्यूल कॉन्फ़िगरेशन फ़ाइल में व्यू मैनेजर ब्लॉक को अपडेट करें - myapp / मॉड्यूल / ट्यूटोरियल / कॉन्फ़िगरेशन / मॉड्यूल.config.php। फिर,JsonStrategy के साथ काम करेंगे JsonModel JSON डेटा को एन्कोड और भेजने के लिए।

'view_manager' => [ 
   'template_map' => array
      ('layout/layout' => __DIR__ . '/../view/layout/newlayout.phtml'), 
   'template_path_stack' => [ 
      'tutorial' => __DIR__ . '/../view', 
   ], 
   'strategies' => array('ViewJsonStrategy',), 
],

चरण 2: TutorialController.php में ajaxAction विधि जोड़ें

निम्नलिखित कोड के साथ TutorialController.php में ajaxAction विधि जोड़ें -

public function ajaxAction() { 
   $data = $this->bookTable->fetchAll(); $request = $this->getRequest(); $query = $request->getQuery(); if ($request->isXmlHttpRequest() || $query->get('showJson') == 1) { $jsonData = array(); 
      $idx = 0; foreach($data as $sampledata) { $temp = array( 
            'author' => $sampledata->author, 'title' => $sampledata->title, 
            'imagepath' => $sampledata->imagepath ); $jsonData[$idx++] = $temp; 
      } 
      $view = new JsonModel($jsonData); 
      $view->setTerminal(true); } else { $view = new ViewModel(); 
   }  
   return $view; 
}

यहाँ, ajaxAction यह जाँच करेगा कि आवक अनुरोध AJAX है या नहीं। यदि आने वाला अनुरोध AJAX है, तोJsonModelउत्पन्न होगा। अन्यथा, एक सामान्यViewModel उत्पन्न होगा।

दोनों मामलों में, पुस्तक की जानकारी डेटाबेस से प्राप्त होगी और मॉडल में पॉपुलेटेड होगी। यदि मॉडल एक JsonModel है, तोJsonStrategy लागू किया जाएगा और यह डेटा को जसन के रूप में एन्कोड करेगा और प्रतिक्रिया के रूप में लौटाएगा।

$query->get('showJson') == 1डिबगिंग उद्देश्यों के लिए उपयोग किया जाता है। बस जोड़ दोshowJson=1 url और पेज में json डेटा प्रदर्शित होगा।

चरण 3: ajax.phtml जोड़ें

अब, दृश्य स्क्रिप्ट जोड़ें ajax.phtmlअजाक्सएशन विधि के लिए। इस पृष्ठ में लेबल के साथ एक लिंक होगा -Load book information

उस लिंक पर क्लिक करने से एक AJAX अनुरोध होगा, जो पुस्तक की जानकारी को Json डेटा के रूप में लाएगा और पुस्तक की जानकारी को प्रारूप तालिका के रूप में दिखाता है। AJAX प्रसंस्करण का उपयोग करके किया जाता हैJQuery

पूर्ण कोड सूची इस प्रकार है -

<a id = "loadbook" href = "#">Load book information</a> 
</br> </br> 

<table class = "table"> 
   <tbody id = "book"> 
   </tbody> 
</table>  

<script language = "javascript"> 
$(document).ready(function(){ $("#loadbook").on("click", function(event){ 
      $.ajax({ url: '/tutorial/ajax', type: 'POST', dataType: 'json', async: true, success: function(data, status) { var e = $('<tr><th>Author</th><th>Title</th><th>Picture</th></tr>'); 
            $('#book').html(''); $('#book').append(e); 
            
            for(i = 0; i < data.length; i++) { 
               book = data[i]; 
               var e = $('<tr><td id = "author"></td><td id = "title"></td> <td id="imagepath"><img src = ""/></td></tr>'); $('#author', e).html(book['author']); 
               $('#title', e).html(book['title']); $('#imagepath img', e).attr('src', book['imagepath']); 
               $('#book').append(e); 
            } 
         }, 
         error : function(xhr, textStatus, errorThrown) { 
            alert('Ajax request failed.'); 
         } 
      }); 
   }); 
}); 
</script>

चरण 4: एप्लिकेशन को चलाएं

अंत में, एप्लिकेशन को चलाएं - http://localhost:8080/tutorial/ajax और लोड बुक जानकारी लिंक पर क्लिक करें।

परिणाम निम्नानुसार होगा -

Ajax Page -

Ajax Page with Book Information

Ajax page with debugging information