如何等待所有异步的初始化条件全部加载完成后,再执行方法

Posted 水台无优

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了如何等待所有异步的初始化条件全部加载完成后,再执行方法相关的知识,希望对你有一定的参考价值。

如果是jQuery1.5以上,ajax类函数返回的是deferred对象,jQ有一个方法叫when:

$.when($.get(url1),$.get(url2),$.get(url3)).done(function(){/*code here*/});

如果3次get有先后顺序,可以用pipe:

$.get(url1).pipe($.get(url2)).pipe($.get(url3)).done(function(){/*code here*/});

1.8以上,pipe被弃用,改为then:

$.get(url1).then($.get(url2)).then($.get(url3)).done(function(){/*code here*/});

意义很明显,先get url1 然后get url2 然后 get url3,做完了再执行done的内容。
 
var a1 = $.ajax({url : ‘a‘ , data : {s : true}});
 
a1.done(function(result){
    //可以写它们各自的处理方法,并不冲突
});
 
var a2 = $.ajax({url : ‘a‘ , data : {s : true}});
var a3 = $.ajax({url : ‘a‘ , data : {s : true}});
 
$.when(a1 , a2 , a3).done(function(a1Result , a2Result , a3Result){
  //当三个ajax都完成时才会执行此方法
  //参数分别是三个ajax的返回值
});

以上是关于如何等待所有异步的初始化条件全部加载完成后,再执行方法的主要内容,如果未能解决你的问题,请参考以下文章

运行多个异步任务并等待它们全部完成

如何等待ajax完成再执行相应操作

如何让页面加载完成后执行js

defer 和 async 本地对象和宿主对象

js Promise 等待多个异步操作执行完再去做一些操作

java如何检查执行的线程已卡死