Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

jquery getJSON function timing issue

I think my program is skipping result of JSON call. Is it possible to make a closure function here or make the program wait for JSON call to return?

function username_not_duplicate(username) {
   var function_name = "get_username";
   var parameters = [username];
   var url = "/get_functions.php?function_name=" + function_name + "&parameters=" + parameters;
   $.getJSON(url, function(user_name) {
      if (user_name == true) {     
         return true;
      }
   });
   return false;
}
like image 554
bob Avatar asked Aug 05 '10 20:08

bob


4 Answers

The $.getJSON() API call is asynchronous. You can make it synchronous by using $.ajax() this way:

function username_not_duplicate(username) {
   var function_name = "get_username";
   var parameters = [username];
   var url = "/get_functions.php?function_name=" + function_name + "&parameters=" + parameters;
   var rslt = false;
   $.ajax({
     async: false,
     url: url,
     dataType: "json",
     success: function(data) {
       if (data == true) {     
         rslt = true;
       }
     }
   });
   return rslt;
}
like image 62
Drew Wills Avatar answered Oct 08 '22 10:10

Drew Wills


Drew's answer is nearly perfect, just missing one bracket and comma for IE.

function username_not_duplicate(username) {
   var function_name = "get_username"; 
   var parameters = [username]; 
   var url = "camps/includes/get_functions.php?function_name=" + function_name + "&parameters=" + parameters;
   var rslt = false; 
   $.ajax({ 
         async: false, 
         url: url, 
         dataType: "json", 
         success: function(data) {
           if (data == true) {                   
             rslt = true; 
           }
        }, 
    });
    return rslt; 
}
like image 43
bob Avatar answered Oct 08 '22 11:10

bob


Another choice is to use a call back function and pass it to the function that executes the getJSON as:

//this is the function that executes my getJSON
//callback is the name of my callback function
function getMyData( callback ){

  //here you do your getJSON call
  $.getJSON(url, function(items){

    //do your stuff here

    //call your function here (at the end)
    callback();

  });

}

This way your callback function will be called at the end of the getJSON call.

like image 41
user3245469 Avatar answered Oct 08 '22 10:10

user3245469


Yeap, username_not_duplicate just returns false immediately because getJSON is asynchronous (ie non-blocking). The return true statement just returns true from the response handler. Normally, you shouldn't do such a blocking calls you're trying to achieve. I suppose you can consider remembering of a state of the request somewhere globally.

like image 27
eigenein Avatar answered Oct 08 '22 11:10

eigenein