Ajax中的同步和异步

2018-06-24 01:52:43来源:未知 阅读 ()

新老客户大回馈,云服务器低至5折

var flag=true;
var index=0;
$.ajax({
  url: "http://www.jb51.net/",
  success: function(data){
    flag=false;
  }  
});
while(flag){
  index++;
}
alert(index);
进入死循环
或者
var flag=true;
$.ajax({
  url: "http://www.jb51.net/",
  success: function(data){
    flag=false;
  }  
});
alert(flag);
//返回结果是true; 因为是异步的所以ajax和alert是一起执行的;

 

同步和异步。js是单线程的,由于执行ajax请求会消耗一定的时间,甚至出现了网络故障而迟迟得不到返回结果;这时,如果同步执行的话,就必须等到ajax返回结果以后才能执行接下来的代码,如果ajax请求需要1分钟,程序就得等1分钟。如果是异步执行的话,就是告诉ajax代码“老兄,既然你迟迟不返回结果,我先不等你了,我还有一大堆代码要执行,等你执行完了给我说一下”。

Ajax默认是异步请求的,所以就出现了上面我们看到的结果。也就是ajax里面的代码还没有执行完,先执行了下面的代码。

async默认是true,也就是异步,我们设置为false,即为同步。

标签:

版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有

上一篇:Angular组件——组件生命周期(二)

下一篇:从零搭建 webpack3 环境 #1 - 安装使用