JS中AJAX执行顺序解决问题详情(附解决办法)
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了JS中AJAX执行顺序解决问题详情(附解决办法),小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含1992字,纯文字阅读大概需要3分钟。
内容图文
本篇文章主要的解释了关于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执行顺序解决问题详情(附解决办法)的详细内容,更多请关注Gxl网其它相关文章!
内容总结
以上是互联网集市为您收集整理的JS中AJAX执行顺序解决问题详情(附解决办法)全部内容,希望文章能够帮你解决JS中AJAX执行顺序解决问题详情(附解决办法)所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。