I am using Async XMLHttpRequest to make an API call. Here's the workflow of my program,
first_function(){
var valueToBeReturned = 0;
makeRequest(myCallback)//function for API call
/*rest of the code*/
console.log("print second");
return valueToBeReturned;
}
function makeRequest(callback){
var xhttp = new XMLHttpRequest();
xhttp.open("GET", "my_url", true);
xhttp.send(null);
xhttp.onload = function() {
if(xhttp.readyState === 4) {
if(xhttp.status === 200) {
response = JSON.parse(xhttp.responseText);
callback(null, response);
}
}
}
}
function myCallback(data){
console.log("print first")
}
Now what happens is every time I run it, the entire code in the first function is executed and then the code in makeRequest is executed. I understand JS is synchronous in nature and everything. But I'm not able to get my work done here, which is fisrt it makes API call, then callback is executed, then the code after makeRequest. What am I doing wrong here?
PS this is not the actual code, just to demonstrate the flow of my program
makeRequest(){…}— you forgot thefunctionkeyword and thecallbackparameter. JS is asynchronous in nature.myCallbackcallback. Put the code to be executed after the request in the callback.print secondprinted first before theprint first, which is not unexpected. That is how Async XMLHTTPRequest works.valueToBeReturnedI suggest you returning a promise. Read more about AJAX at developer.mozilla.org/en-US/docs/Web/Guide/AJAX/Getting_Started