如何确保我的函数在所有 ajax 调用后执行
How to make sure my function executes after all ajax calls?
我有一个javascript函数。在这个函数中,我有 3 个 ajax 调用。如何确保在这些 ajax 调用完成后执行我的另一个函数?
function a(){
for(var i=0;i<3;i++)
$.post("somePage.php").done(function(){
do stuff here...
});
return false;
}
function b(){
//.....
}
我的函数 B 会在 AJAX 调用完成后执行吗?
一个完整的解决方案将是这样的
function a() {
var array = [], xhr;
for (var i = 0; i < 3; i++) {
xhr = $.post("somePage.php").done(function () {});
array.push(xhr)
}
//create a promise which will be called after all the ajax request are completed
return $.when.apply($, array);
}
function b() {
//.....
}
//on succss callback of all the ajax requests created in a call b
a().done(b)
编写一个增量检查,在每个返回的 Ajax 上递增,如下所示:
increments = 0;
$.post("somePage.php").done(function(){
// Check if the increments are total to 3
++increments;
if(increments == 3) {
//do something now such as call b();
}
//do stuff here...
});
jQuery ajaxStop 方法允许您注册一个处理程序,以便在所有 Ajax 请求完成时调用。
相关文章:
- 另一个ajax调用中的Jquery ajax调用在for循环中没有按预期工作
- Javascript/jQuery中的并行Ajax调用
- 任何方式使AJAX调用Gmail API,而无需通过JS库
- node.js请求数据事件未在CORS ajax调用中触发
- 如何从ajax调用返回.wrap()元素
- Ajax调用在Firefox中不会自动响应
- AJAX调用中的非法调用
- 使用AJAX调用将GeoJSON数据拉入传单
- 在MVC 4中,对Controller的Ajax调用为空
- Jquery:对返回JSON数据的php脚本的Ajax调用
- 在ajax调用中阻止来自JS对象的函数
- 如何在MVC5中ajax调用的部分视图中引用外部javascript
- 页面加载后的Ajax调用
- 如何使用Ajax调用特定的控制器和操作来重定向用户
- curl和fileget_contents在ajax调用后不起作用
- 在任何AJAX调用之前触发一个javascript函数
- 无法在mvc视图中使用ajax调用获取操作返回的模型对象列表
- Ajax调用ERror Cross Origin REquest:在rails中自动完成大学列表
- ASP.NET MVC 3-在ajax调用后,重定向到新页面或生成页面刷新
- 点击功能没有'ajax调用动态元素(Backbone)后无法工作