Skip to main content

Call ajax after completion of another ajax ,Wait for ajax to return.


Lets suppose you are trying to set loggedIn username to the header of your web page and you have 2 ajax which get fired

1st Ajax : Which is decorating the header

2nd Ajax : Which gets the username

So if 2nd AJAX become first in the race then username is not visible to you as 1st ajax is responsible for decorating the header and if there is no header there is no place where you can set header.

so to be very sure that our username is visible on the screen, we should wait for the header(1st ajax)to complete


document ready function:


$(document).ready(function () {

 //calling this method to get the fetch logged in user

 fetchloggeInUser();

});



1st Ajax request : run in parallel with 2nd ajax 

this is building our header part
(function ($) {
  $.pageDecorate = {
  //declare a global variable so that it can be used.
  decorateDeferred : null,
  //set response of the ajax in a variable
  var decoratorDeferred = $.ajax({
    url : 'setHeader',
    type : 'get',
    data : decorateHeaderData,
    dataType : 'json',
    success : function (data) {
     //response of testAjax sets in decorateDeferred
     decorateDeferred = $.pageDecorate.testAjax();
    }
   });


Global declaration :

  //set value of global variable decorateDeferred so
  // that it can be use as a reference

  $.pageDecorate.decorateDeferred = decorateDeferred;


  },

Method to call :
 testAjax : function () {

  var navHtml = '<ul>';
  navHtml += '<div class="divHeader" title="login">';
  navHtml += '<div class="role">';
  navHtml += '</div>';
  navHtml += '</div>';
  navHtml += '</ul>';
  //append this to header of your page
  $('.header').append(navHtml);
 }
});


2nd Ajax:

fetchloggeInUser : function () {

 $.ajax({

  url : "loggedInUser",

  type : "POST",

  success : function (data) {

   //although this success block call when ajax get 
   //fired but this code runs when it get response
   //after the success response of $.pageDecorate.decorateDeferred 
   this below success get called

   $.pageDecorate.decorateDeferred.success(function () {

    $('.divHeader').find('.role').text(userName);

   });

  }

 });

}


That 's it you are done.

Comments

Popular posts from this blog

Extent report plugin for cucumber framework

Extent Reports  are the most popular  reporting  used with Selenium. ExtentReport API makes our life easy to generate interactive  report  with simple configuartions. It supports almost all Java and .NET test frameworks such as TestNG , JUnit , NUnit etc Here we are discussing about  a plugin which is build on  Extent Report specially for Cucumber. This plugin is used to simple out the implementation of  Extent Report  in  Cucumber Framework .  We are creating a maven project to implement the integration of our plugin with cucumber 1. Create new maven project in any tool eclipse/sts/intellij 2. Open pom.xml and update below entries. Step 1 : Add Cucumber Extent Reporter library to Maven Project Add  cucumber-extentsreport <dependency>      <groupId> com.vimalselvam </groupId>      <artifactId> cucumber-extentsreport </artif...

java: You aren't using a compiler supported by lombok, so lombok will not work and has been disabled.

  In order to make projects compile with the existing builds of Lombok processor, as a workaround you can use the flag -Djps.track.ap.dependencies=false which should be added to File | Settings | Build, Execution, Deployment | Compiler | Build process VM options field. This will disable collection of dependencies specified by an annotation processor when Filer methods are called

Learn Docker Beginner

If you are in Software industry then you must use this phrase to prove yourself. But I m sure after reading this tutorial you won't be able to say this again. 1. What is Docker Docker is a software platform designed to make it easier to create, deploy, and run applications by using containers. It allows developers to package up an application with all the parts it needs in a container, and then ship it out as one package 2. Virtual Machines vs. Docker Virtual machines have a full OS with its own memory management installed with the associated overhead of virtual device drivers. Every guest OS runs as an individual entity from the host system. On the other hand Docker containers are executed with the Docker engine rather than the hypervisor. 3. Introduction to Dockerfiles, images and containers A Dockerfile is a text file that Docker reads in from top to bottom. It contains a bunch of instructions which informs Docker HOW the Docker ima...