gpt4 book ai didi

javascript - 检测多个异步 javascript $.ajax 调用的完成

转载 作者:搜寻专家 更新时间:2023-11-01 05:07:32 24 4
gpt4 key购买 nike

我有一个 javascript 函数,它进入循环并为每个循环发出异步 ajax 调用。我需要知道所有 ajax 调用何时返回并得到处理,因为我想在那个时候更新 UI。

循环如下:

function sync_SyncLocalStorageToServer() {
if (helper_IsAppOnline()) {
$.log('sync_SyncLocalStorageToServer detects app is ONLINE');
// Post each cached entry to the server - this is the main sync function
for (var i = 0, len = localStorage.length; i < len; i++) {
var lskey = localStorage.key(i);
if (lskey.substr(0, 8) === 'response') {
$.log('Sync found response with key=' + lskey);
var postdata = localStorage.getItem(lskey); // Get the form data
$.log('Calling server with ls response:' + postdata);
var localkey = lskey;
$.ajax({
type: "POST",
dataType: 'json',
url: "/Profile/PostForm",
data: { jsonpost: postdata },
success: function (data) {
if (data.rc == "success") {
localStorage.removeItem(data.localStorageKey); // Remove the relevant localStorage entry
$.log('ServerSuccess:' + data.message + ',removed localStorageKey=' + data.localStorageKey);
} else {
$.log('ServerUnhappy:' + data.message + ',did not remove localStorageKey=' + data.localStorageKey);
}
}
, error: function (data) {
$.log('ERR:' + data);
}
});
}
}
}
else {
$.log('sync_SyncLocalStorageToServer detects app is OFFLINE');
}
}

当最后一次异步 ajax 调用最终从服务器返回时,调用 UI 刷新函数的最简单方法是什么?

谢谢。

最佳答案

计算您执行 AJAX 请求的次数,然后计算您看到调用完成回调的次数。一旦回调完成计数等于您发出 ajax 调用的次数,您就知道您完成了。

var total = arr.length;
var count = 0;
for(var i = 0; i < arr.length; i++){
$.ajax({
// other options
complete: function(){
count++;
if(count == total){
// all finished!
}
}
});
}

请注意,我使用的是“完成”回调,而不是“成功”,因为如果其中一个请求失败,将不会调用“成功”,但会调用“完成”。此外,我首先在“总计”中声明了预期金额,而不是在此示例中进行计数。这只是避免了在您发布所有待处理的 ajax 请求之前完成所有未决 ajax 请求并因此具有匹配计数的不太可能(尽管在技术上是可能的)情况。

关于javascript - 检测多个异步 javascript $.ajax 调用的完成,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6309080/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com