zoukankan      html  css  js  c++  java
  • JS 中 AJAX执行顺序解决方法

    在JS中我们会遇到执行顺序的问题,尤其是AJAX的执行顺序,js中默认的执行顺序是从上往下执行。

    看下面的一段代码

    callback:function(value, validator, $field){
            $.ajax({
              url : window.ctx+"/sys/manager/validateLoginName",
              data:{loginName:value},
              type : 'post',
              dataType : "json",
              async:true,  
              success: function(result){
              if(result!=null)
              globalVariable.flag=result;
              alert(1)
                   }});
              alert(2)
              if(globalVariable.flag!=1)return true;
              if(globalVariable.flag==1)return false;    
      }

    由于这里的AJAX是异步请求,所以在浏览器中会先弹出2在弹出1
    这样就会出现问题  假如flag默认是0,在执行完AJAX之后会变成1,那么if语句其实是用0去做的判断,与我们的目的不相符,我们想要的是用AJAX执行完之后赋值的flag去做if判断

    解决

    第一种方法
    之所以出现这样的问题是因为AJAX采用了异步请求,所以如果我们想先弹出1再弹出2只需要把AJAX改为同步即可,也就是将async改为false

    这样如果AJAX没有执行完页面会出现假死状态,停止往下执行,只有当AJAX回调走完以后才会往下走

    当然我们使用AJAX就是为了异步,所以上面的方法是遇到特殊的需要了可以这样处理

    第二种方法

    第二种办法是比较常用的

    例如下面一段代码

    function test(){
        $.ajax({
              url : window.ctx+"/sys/manager/addUserRole",
              data:formData,
              type : 'post',
              dataType : "json",
                  processData:false,
                  contentType:false,
              success: function(result){
                  if(result!=null){
                      testCallback();
                  }
            }});
             test2();
     }
    function testCallback(){
        alert(1)
    }
    function test2(){
        alert(2)
    }

    AJAX是异步的,我们希望先弹出1再弹出2我们只需要把test2放在test的回调函数中即可

    像这样

    function test(){
        $.ajax({
              url : window.ctx+"/sys/manager/addUserRole",
              data:formData,
              type : 'post',
              dataType : "json",
              processData:false,
              contentType:false,
              success: function(result){
                  if(result!=null){
                      testCallback();
                  }
            }});
    }
    function testCallback(){
        alert(1)
        test2()
    }
    function test2(){
        alert(2)
    }

    希望对大家有帮助

    本文转自:https://blog.csdn.net/qq_33251859/article/details/75046952

  • 相关阅读:
    PHP递归方法实现前序、中序、后序遍历二叉树
    php循环方法实现先序、中序、后序遍历二叉树
    Mac charles 抓取https请求,安装证书后还是显示unknown
    PHP工厂模式
    PHP策略模式2
    PHP单例模式
    PHP 面试知识点整理归纳
    十大迷你iPhone天气应用
    来自极客标签10款最新设计素材-系列十三
    帮助快速生成页面固定显示元素的jQuery插件
  • 原文地址:https://www.cnblogs.com/sky6699/p/14790525.html
Copyright © 2011-2022 走看看