javascript – AJAX延迟下一行的执行
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了javascript – AJAX延迟下一行的执行,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含1149字,纯文字阅读大概需要2分钟。
内容图文
![javascript – AJAX延迟下一行的执行](/upload/InfoBanner/zyjiaocheng/811/26dac1973a2c4438b2562addb5c5b6b3.jpg)
鉴于以下代码,任何人都可以帮助我理解为什么在第二个警报之后执行第一个警报?我相信这是因为ajax有一个很小的延迟,直到它取出数据,如果我错了,请纠正我.谢谢你提前.
Javascript code:
window.onload = function() {
arry = new Array();
jQuery.ajax({
type: "GET",
url: "index.php?op=17&id=@@postID@@&action=fetch",
dataType: "text",
success: function(response){
var e = response;
console.log(JSON.parse(e));
arry = JSON.parse(e)
alert(e); //1st alert
}
});
alert("test") //2nd alert
}
解决方法:
AJAX中的第一个“A”代表异步.这意味着它在您的代码中没有阻塞,因此在您的AJAX请求之后立即调用alert(‘test’),而只有在AJAX请求从服务器收到成功响应后才调用alert(e).
你提到的“小延迟”不是这样,而是服务器执行任何代码并返回响应所花费的时间.
如果您绝对需要同步处理请求,则可以将async属性传递给AJAX调用,如下所示:
window.onload = function() {
var arry = [ ];
jQuery.ajax({
type: "GET",
url: "index.php?op=17&id=@@postID@@&action=fetch",
dataType: "json",
async: false
}).done(function(response) {
arry = response
alert(response); //1st alert
});
alert("test") //2nd alert
}
请注意,我已经稍微更新了代码以使用done()promise.另外,指定dataType:“json”否定了在响应文本上调用JSON.parse()的需要.
内容总结
以上是互联网集市为您收集整理的javascript – AJAX延迟下一行的执行全部内容,希望文章能够帮你解决javascript – AJAX延迟下一行的执行所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。