I have a webpage with different elements (a list of links and two select boxes) connected between them. Clicking on them may affect one of the other element and all of their values contribuite to update a value to show on the page.
So, the code is this:
$(document).ready(function() {
var someVar = '';
$("select#size").bind('change', function() {
someVar = $(this).val();
console.log('first');
});
my_change();
console.log('second' + someVar);
});
function my_change() {
$.getJSON("photos/change_product", {json_stuff}, function(data) {
var options = [];
for (var i = 0; i < data.length; i++) {
options.push('<option value="' + data[i].id + '">' + data[i].label + '</option>');
}
$("select#size").trigger('change');
$("select#options").html(options.join('')).trigger('change');
})
};
};
When I load the page the my_change function is called. It does some stuff and then triggers a change event on a select-box. I need to update a value using what’s inside this select box and only then let the execution to proceed. So what I need this code to do would be to print ‘first’, and then ‘second’ with the value of the variable. What actually happen is that it prints ‘second’ ‘first’.
I think it’s because I’m doing asynchronous calls. What can I do?
The ‘second’
console.log()is being called first since the asynchronous$.getJSON()call waits for the response from the server before firing its callback function. You could save the jqXHR object to a variable and then use that to run your ‘second’consone.log()with$.when():Here is documentation for
$.when(): http://api.jquery.com/jquery.whenA quick side-note: it is generally slower to add a tag-type to a selector, especially when you are selecting IDs as that is already a very fast method of selecting elements.