I am working on a flask application and there is this javascript function associated with a form
function applyQueries() {
// does some things
if(currentCatalog != ''){
addCatalogFilters(currentCatalog);
}
$.ajax({
type: 'POST',
url: "/applyQueries",
contentType: "application/json",
success:function(response){
// does some stuff here
})
}
The addCatalogFilters() function is also an ajax call. Both these calls change some variables in the python side of things. What I want to know is if the first ajax call (in addCatalogFilters), is guaranteed to execute and return before the second one. I am ending up with weird results that appear to be race conditions based on the order the ajax calls execute. Is this possible with code structured like this? Also if so, how can I fix it?
// Add user catalog filters
function addCatalogFilters() {
catalog = currentCatalog;
formData = new FormData(document.getElementById('catalogFilterForm'));
$.ajax({
type: 'POST',
url: "/addCatalogFilters",
data: formData,
processData: false,
contentType: false,
success: function (response){
document.getElementById(catalog + 'close').style.display = 'block';
document.getElementById(catalog + 'check').style.display = 'none';
addBtns = document.getElementsByClassName("addBtn");
removeBtns = document.getElementsByClassName("removeBtn");
for (i = 0; i < addBtns.length; i++) {
addBtns[i].style.display = "none";
removeBtns[i].style.display = "inline-block";
}
}
})
};
4
Answers
You could try using async/await like this:
By usinc async/await, your code will wait until the
addCatalogFilters()
function has resolved. However, for this to work, theaddCatalogFilters()
function should be async with a return value. Something like this:You can ensure with success function of ajax. First call a ajax (let’s say ajax1) then call another ajax call within the success function of first ajax call (ajax1 success function).
It may not be the optimum way. But guarantee one ajax call is complete before calling another.
Depending on how applyQueries is called, you may need to have an await or .then where you call it. Note that you can also use “result = await addCatalogFilters(currentCatalog)” to put the ajax result into a variable result that you can work with and pass to your $.ajax call in applyQueries. I don’t know the nature of your code, so I can’t make any direct suggestions.
You can use
async/await
. However, as no one has mentioned, I would like to demonstrate how you can accomplish this withPromise
.Lets define two functions:
Now you can make sure that
second_function()
gets called only after the execution ofajax
request infirst_function()
by following approach: