Hey, Ich arbeite an einer jQuery each() - Schleife, die eine Ajax-Anfrage und eine setTimeout enthält. Das gibt mir einige Probleme mit dem Programmablauf.Ausführen einer Funktion, nachdem jede Schleife abgeschlossen wurde
xml_queries: function (data) {
var values = [];
// ...
$.each(data, function(index, value) {
// ...
// Start xml query
var i = 0;
get_data(value.value);
function get_data(value) {
$.ajax({
type: 'POST',
url: '/admin/scanner/get_music_data/' + value,
dataTaype: 'json',
success: function(response) {
if (response === 'FALSE') {
// Start recursion - up to 3 Retries
if (++i <= 3) {
setTimeout(function() {
get_data();
}, 100);
} else {
// ...
}
} else {
values.push(response);
}
}
});
}
});
// return values;
console.log(values);
}
Mein Problem ist, dass die console.log() in der letzten Zeile sofort ausgelöst wird (während der Schleife noch Datenverarbeitung ist). Gibt es keine einfache Möglichkeit, auf die Schleife zu warten? \:
Mit freundlichen Grüßen!
Es ist das übliche Ajax-is-Asynchron-Problem. Es gibt eine Menge Fragen zu SO in diesem einen oder anderen Geschmack. –