| 通常使用Ajax的时候,往往都是因为执行先后的问题所烦恼,今天就说下Ajax执行完后在执行其他操作的方法。 
 1.运用Ajax的 async 属性设置为 false,将 ajax 同步执行。
 
 [JavaScript] 纯文本查看 复制代码 // 声明一个表示状态的全局变量 status
var status = false;
// ajax
$.ajax({
    url:"/checkUsername",
    type:"post",
    // ajax 同步执行
    async:false,
    success:function(){
        status = true;  
	}  
});
// 根据 status 的状态 进行后续操作
function(){
  if(status){
    // 后续操作
	}  
}这种情况下有时表现形式不太友好。
 2.利用 jquery 的 when().done 函数 等待 ajax 执行结束之后再进行后续操作。
 
 此时的 status 是在 ajax 执行完成后被重新赋值后的 status ,值为 true。[JavaScript] 纯文本查看 复制代码 // 声明一个表示状态的全局变量 status
var status = false;
// ajax
myajax = $.ajax({
    url:"/checkUsername",
    type:"post",
    success:function(){
        status = true;  
}  
});
// 根据 status 的状态 进行后续操作
function(){
  // myajax 请求完毕时执行
  $.when(myajax).done(function(){
      if(status){
        // 后续操作
      }  
    }) ;
}
 推荐使用第二种方法。希望可以帮助到大家!
 
 |