本文共 683 字,大约阅读时间需要 2 分钟。
说简单点,ajax默认是异步加载的,也就是说第一个fun请求数据时,数据还未返回时便开始执行第二个fun了,
如果将其设置为同步请求,则会等第一个function执行完后才会加载第二个function了
异步请求:
var flag=true;$.ajax({ url: "http://www.jb51.net/", success: function(data){ flag=false; } });alert(flag);alert出flag的值是多少呢?没错,是true!
var flag=true;var index=0;$.ajax({ url: "http://www.jb51.net/", async:false, success: function(data){ flag=false; } });while(flag){ index++;}alert(index);
async默认是true,也就是异步,我们设置为false,即为同步。
js是单线程的,由于执行ajax请求会消耗一定的时间,甚至出现了网络故障而迟迟得不到返回结果;这时,如果同步执行的话,就必须等到ajax返回结果以后才能执行接下来的代码,如果ajax请求需要1分钟,程序就得等1分钟。如果是异步执行的话,就是告诉ajax代码“老兄,既然你迟迟不返回结果,我先不等你了,我还有一大堆代码要执行,等你执行完了给我说一下”。
Ajax默认是异步请求的,所以就出现了上面我们看到的结果。也就是ajax里面的代码还没有执行完,先执行了下面的代码。
转载地址:http://tpqii.baihongyu.com/