JS中AJAX执行顺序解决问题详情(附解决办法)

本篇文章主要的解释了关于js中ajax执行顺序解决的问题,现在让我们来看看这篇关于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判断(想看更多就到PHP中文网AJAX开发手册栏目中学习)

解决:

第一种方法

之所以出现这样的问题是因为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)}

登录后复制

本篇文章到这就结束了(想看更多就到PHP中文网AJAX使用手册栏目中学习),有问题的可以在下方留言提问。

以上就是JS中AJAX执行顺序解决问题详情(附解决办法)的详细内容,更多请关注【创想鸟】其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2741545.html

(0)
上一篇 2025年3月8日 02:35:47
下一篇 2025年3月1日 01:50:32

AD推荐 黄金广告位招租... 更多推荐

相关推荐

发表回复

登录后才能评论