详解JavaScript for循环中发送AJAX请求问题


Posted in Javascript onJune 23, 2020

首先说,出现这个问题的场景是很少见的,因为有太多更好解决方法。今天搞ajax的时候,一个有趣的地方,,每个迭代中都要发送一个get请求,因为迭代的速度太快,一个请求还没有完成就进行下一个迭代,在chrome和ff上,除最后一个请求外,其它请求都被取消了。所以该怎么办呢?设置延时(不太好)还是其他办法?
 办法有很多,比如设置休眠,迭代等等, 我采用的是另外两种解决办法。

一、同步的ajax请求,而ajax请求默认是异步的,所以要设置为false。

function creatXMLHttpRequest() {
 var xmlHttp;
 if (window.ActiveXObject) {
 return xmlHttp = new ActiveXObject("Microsoft.XMLHTTP");
 } else if (window.XMLHttpRequest) {
 return xmlHttp = new XMLHttpRequest();
 }
}
function disButton(name, actionName, resquestParmName) {
 var path = document.getElementById("path").value;
 var xmlHttp = creatXMLHttpRequest();

 var invoiceIds = new Array();
 invoiceIds = document.getElementsByName(name);
 // 迭代的速度快于发送请求+收到回复的时间 所以一次get请求都还没有完成就进行了下一次请求
 for (i = 0; i < invoiceIds.length; i++) { 
 var invoiceId = invoiceIds[i].value;
 var url = path + "/" + actionName + ".action?" + resquestParmName + "="
 + invoiceId;
 xmlHttp.onreadystatechange = function() {
 if (xmlHttp.readyState == 4) {
 if (xmlHttp.status == 200) {

  var result = xmlHttp.responseText;
  if (result == "0") {
  document.getElementById("btn" + invoiceId).disabled = "disabled";
  }
 }
 }
 }
 xmlHttp.open("GET", url, false);
 xmlHttp.send(null);
 } 
}

这样,用同步的ajax请求,就会等服务器响应后,执行完代码,再继续迭代。但是好像不推荐这样做。

详解JavaScript for循环中发送AJAX请求问题

二、采用异步的方式,但要记住,每次迭代都要创建一个新XMLHttpRequest对象,不能重用。

function creatXMLHttpRequest() {
 var xmlHttp;
 if (window.ActiveXObject) {
 return xmlHttp = new ActiveXObject("Microsoft.XMLHTTP");
 } else if (window.XMLHttpRequest) {
 return xmlHttp = new XMLHttpRequest();
 }
}
function disButton(name, actionName, resquestParmName) {
 var xmlHttp;
 var path = document.getElementById("path").value;
 var invoiceIds = new Array();
 invoiceIds = document.getElementsByName(name);
 // 迭代的速度快于发送请求+收到回复的时间 所以一次get请求都还没有完成就进行了下一次请求
 for (i = 0; i < invoiceIds.length; i++) { 
 xmlHttp = creatXMLHttpRequest();
 var invoiceId = invoiceIds[i].value;
 var url = path + "/" + actionName + ".action?" + resquestParmName + "="
 + invoiceId;
 fu(xmlHttp,url,invoiceId);
 } 
}
function fu(xmlHttp,url,invoiceId){
 xmlHttp.onreadystatechange = function() {
 if (xmlHttp.readyState == 4) {
 if (xmlHttp.status == 200) {
 
 var result = xmlHttp.responseText;
 if (result == "0") {
  
  document.getElementById("btn" + invoiceId).disabled = "disabled";
 }
 }
 }
 }
 //
 xmlHttp.open("GET", url, true);
 xmlHttp.send(null);
}

由于JS的for循环与ajax非同步运行,因此导致for循环结束了而ajax却还未执行。如果采用的是异步请求的方式,如果每次迭代的时候都去new一个XMLHttpRequest,这样每次请求都能完成,但是结果还是还是不准确,有些程序还未被执行。
明白了,原来是每次迭代去执行几行代码,应该把发送ajax异步请求的代码放在一个函数中,每次迭代就去调用这个函数,这样就行了。

性能上,对于这种迭代ajax请求,似乎同步的方式性能更高。

详解JavaScript for循环中发送AJAX请求问题

这个问题解决了,也加深了对ajax、http的理解。

以上就介绍了JavaScript for循环中发送AJAX请求的问题,希望对Javascript教程有兴趣的朋友有所帮助。

Javascript 相关文章推荐
用js来解决ajax读取页面乱码
Nov 28 Javascript
jQuery.autocomplete 支持中文输入(firefox)修正方法
Mar 10 Javascript
jqPlot 基于jquery的画图插件
Apr 26 Javascript
Javascript中实现String.startsWith和endsWith方法
Jun 10 Javascript
浅谈js里面的InttoStr和StrtoInt
Jun 14 Javascript
基于JS如何实现给字符加千分符(65,541,694,158)
Aug 03 Javascript
jQuery+正则+文本框只能输入数字的实现方法
Oct 07 Javascript
浅谈javascript中的数据类型转换
Dec 27 Javascript
vue cli 3.0 搭建项目的图文教程
May 17 Javascript
Vue登录主页动态背景短视频制作
Sep 21 Javascript
vue监听用户输入和点击功能
Sep 27 Javascript
JS PHP字符串截取函数实现原理解析
Aug 29 Javascript
Jquery判断form表单数据是否变化
Mar 30 #Javascript
基于javascript实现tab选项卡切换特效调试笔记
Mar 30 #Javascript
javascript实现数字倒计时特效
Mar 30 #Javascript
基于javascript实现样式清新图片轮播特效
Mar 30 #Javascript
网页中JS函数自动执行常用三种方法
Mar 30 #Javascript
Jquery轮播效果实现过程解析
Mar 30 #Javascript
修复jQuery tablesorter无法正确排序的bug(加千分位数字后)
Mar 30 #Javascript
You might like
Linux下CoreSeek及PHP扩展模块的安装
2012/09/23 PHP
深入phpMyAdmin的安装与配置的详细步骤
2013/05/07 PHP
探讨GDFONTPATH能否被winxp下的php支持
2013/06/21 PHP
PHP生成可点击刷新的验证码简单示例
2016/05/13 PHP
PHP大神的十大优良习惯
2016/09/14 PHP
php计算多个集合的笛卡尔积实例详解
2017/02/16 PHP
PHP实现的多维数组排序算法分析
2018/02/10 PHP
PHP+RabbitMQ实现消息队列的完整代码
2019/03/20 PHP
JS实现日期加减的方法
2013/11/29 Javascript
利用了jquery的ajax实现二级联互动菜单
2013/12/02 Javascript
Javascript单元测试框架QUnitjs详细介绍
2014/05/08 Javascript
理解javascript中DOM事件
2015/12/25 Javascript
体验jQuery和AngularJS的不同点及AngularJS的迷人之处
2016/02/02 Javascript
js 自带的 map() 方法全面了解
2016/08/16 Javascript
javascript使用闭包模拟对象的私有属性和方法
2016/10/05 Javascript
微信小程序 页面跳转和数据传递实例详解
2017/01/19 Javascript
springMVC + easyui + $.ajaxFileUpload实现文件上传注意事项
2017/04/23 Javascript
微信小程序解除10个请求并发限制
2018/12/18 Javascript
node读写Excel操作实例分析
2019/11/06 Javascript
jQuery实现消息弹出框效果
2019/12/10 jQuery
js实现百度登录窗口拖拽效果
2020/03/19 Javascript
原生js实现贪吃蛇游戏
2020/10/26 Javascript
[01:33:25]DOTA2-DPC中国联赛 正赛 Elephant vs IG BO3 第一场 1月24日
2021/03/11 DOTA
python动态性强类型用法实例
2015/05/09 Python
python 判断是否为正小数和正整数的实例
2017/07/23 Python
python3 selenium 切换窗口的几种方法小结
2018/05/21 Python
Python将多个list合并为1个list的方法
2018/06/27 Python
Python Image模块基本图像处理操作小结
2019/04/13 Python
python lxml中etree的简单应用
2019/05/10 Python
如何让Java程序执行效率更高
2014/06/25 面试题
中考标语大全
2014/06/05 职场文书
青年文明号申报材料
2014/12/23 职场文书
收入证明申请书
2015/06/12 职场文书
nginx反向代理时如何保持长连接
2021/03/31 Servers
mysql连接查询中and与where的区别浅析
2021/07/01 MySQL
Oracle 死锁的检测查询及处理
2021/09/25 Oracle