zoukankan      html  css  js  c++  java
  • Ajax中的同步和异步

    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,即为同步。

  • 相关阅读:
    JQuery学习笔记(1)——选择器
    Web前端——表单提交和Js添加选项
    Web前端——JavaScript练习
    Web前端——css
    Web前端——JavaScript笔记
    sirius的学习笔记(2)
    sirius的python学习笔记(1)
    Get和Post的请求
    IIS的配置
    一般处理程序aspx
  • 原文地址:https://www.cnblogs.com/DSC1991/p/8757901.html
Copyright © 2011-2022 走看看