I have this simple function that fetches gis data from mapquest:
function reverseGeocoding(lat,lng){
var url = 'http://open.mapquestapi.com/nominatim/v1/reverse?format=json&lat=' + lat + '&lon=' +lng+' &zoom=18&addressdetails=1';
$.ajax({
url: url,
crossDomain:true,
success: function(response){
$("#revgeo-place").html(response.display_name);
}
});
}
How can I improve it so that when this function is called from another function the return value is updated asynchronously?
I don't want to explicitly put any DOM reference in the function, and I want to keep the ajax asynchronous, ideally should be something like this:
$("#revgeo-place").html(reverseGeocoding(lat,lng).display_name);
function reverseGeocoding(lat,lng){
var url = 'http://open.mapquestapi.com/nominatim/v1/reverse?format=json&lat=' + lat + '&lon=' +lng+' &zoom=18&addressdetails=1';
$.ajax({
url: url,
crossDomain:true,
success: function(response){
console.log(response);
return response;
}
});
}
It looks that when I do this the DOM object does not update, and after then the function returns the response.
Any ideas would be helpful thanks!
You may use a callback:
So your
reverseGeocoding
function is agnostic to DOM.Your second example doesn't work because the value of the AJAX request has not returned when you set the value of
$("#revgeo-place").html()
.If you are looking to be able to amend the element which is updated, add it as a parameter to your function like this:
Return the deferred object from the ajax call, and use the
done()
function to update the HTML when the ajax call is done :You could add a
onSuccess
parameter to thereverseGeocoding
function that is called when the ajax function completes