I’m using a jQuery JSON function inside another function, how can I return an array made in the jQuery function as the return value of my parent function?
This is the basic setup:
function getFlickrSet(flickr_photoset_id){
var images = [];
images = $.getJSON(url, function(data){ return data; // I HAVE THE DATA HERE };
return images // I HAVE NO DATA HERE
}
var myImages = getFlickrSet(23409823423423);
alert(myImages); // this gives me nothing
I have set up an example on JS Fiddle. Where is my code incorrect?
Well, Ajax is asynchronous (that’s what the ‘A’ stands for), so you must do this in an asynchronous way, which boils down to callbacks. What you need to do is pass a callback function to your outer function that you want to be called (“called back,” if you will) when the Ajax request completes. You could just give it ‘alert’ like this:
…but more likely you’d write something like this: