ajax is a modern technology in web programming. it provides options to send and receive data in a webpage asynchronously, without refreshing the page. zend framework provides an option to work with the json model through zend-view and zend-json component. let us learn the zend ajax programming in this chapter.
install json component
the zend json component can be installed using the composer command as specified below −
composer require zendframework/zend-json
concept
zend framework provides two methods to easily write an ajax enabled web application. they are as follows −
- the isxmlhttprequest() method in the request object – if an ajax request is made, the request object's isxmlhttprequest() method returns true, otherwise false. this method is used to handle an ajax request properly in the server side. 
if ($request->isxmlhttprequest()) { 
   // ajax request 
} else { 
   // normal request 
}
- the zend/view/model/jsonmodel – the jsonmodel is an alternative for viewmodel to be used exclusively for ajax and the rest api scenarios. the jsonmodel along with jsonstrategy (to be configured in the module's view manager block) encodes the model data into json and returns it as a response instead of views (phtml). 
ajax – working example
let us add a new ajax page, ajax in the tutorial module and fetch the book information asynchronously. to do this, we should adhere to the following steps.
step 1: add jsonstrategy in module configuration
update the view manager block in the tutorial module configuration file – myapp/module/tutorial/config/module.config.php. then, jsonstrategy will work with jsonmodel to encode and send the json data.
'view_manager' => [ 
   'template_map' => array
      ('layout/layout' => __dir__ . '/../view/layout/newlayout.phtml'), 
   'template_path_stack' => [ 
      'tutorial' => __dir__ . '/../view', 
   ], 
   'strategies' => array('viewjsonstrategy',), 
],
step 2: add ajaxaction method in the tutorialcontroller.php
add the ajaxaction method in the tutorialcontroller.php with the following code −
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; 
} 
here, ajaxaction will check whether the incoming request is ajax or not. if the incoming request is ajax, then the jsonmodel will be created. otherwise, a normal viewmodel will be created.
in both cases, the book information will be fetched from database and populated in the model. if the model is a jsonmodel, then jsonstrategy will be invoked and it will encode the data as json and return as response.
the $query->get('showjson') == 1 is used for debugging purposes. just add showjson=1 in the url and the page will display the json data.
step 3: add ajax.phtml
now, add the view script ajax.phtml for the ajaxaction method. this page will have a link with the label – load book information.
clicking that link will do an ajax request, which will fetch the book information as json data and shows the book information as a formatted table. the ajax processing is done using the jquery.
the complete code listing is as follows −
<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>
step 4: run the application
finally, run the application − http://localhost:8080/tutorial/ajax and click the load book information link.
the result will be as shown below −
ajax page −
 
ajax page with book information
 
ajax page with debugging information
 
