详解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 相关文章推荐
javascript scrollTop正解使用方法
Nov 14 Javascript
用Javascript获取页面元素的具体位置
Dec 09 Javascript
js转化毫秒为时间格式代码
Apr 10 Javascript
ExpressJS入门实例
Jan 14 Javascript
javascript密码强度校验代码(两种方法)
Aug 10 Javascript
javascript实现状态栏中文字动态显示的方法
Oct 20 Javascript
Js与Jq获取浏览器和对象值的方法
Mar 18 Javascript
jQuery实现点击任意位置弹出层外关闭弹出层效果
Oct 19 Javascript
浅谈js-FCC算法Friendly Date Ranges(详解)
Apr 10 Javascript
基于javascript 显式转换与隐式转换(详解)
Dec 15 Javascript
一篇文章介绍redux、react-redux、redux-saga总结
May 23 Javascript
vue动态循环出的多个select出现过的变为disabled(实例代码)
Nov 10 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
php empty,isset,is_null判断比较(差异与异同)
2010/10/19 PHP
php 求质素(素数) 的实现代码
2011/04/12 PHP
php中jpgraph类库的使用介绍
2013/08/08 PHP
Smarty模板变量与调节器实例详解
2019/07/20 PHP
php桥接模式应用案例分析
2019/10/23 PHP
javaScript 判断字符串是否为数字的简单方法
2009/07/25 Javascript
Jsonp 跨域的原理以及Jquery的解决方案
2010/05/18 Javascript
jQuery的链式调用浅析
2010/12/03 Javascript
js实现单行文本向上滚动效果实例代码
2013/11/28 Javascript
javascript实现随时变化着的背景颜色
2015/04/02 Javascript
原生JavaScript实现瀑布流布局
2020/06/28 Javascript
Bootstrap实现下拉菜单效果
2016/04/29 Javascript
jquery实现表格中点击相应行变色功能效果【实例代码】
2016/05/09 Javascript
Javascript基础教程之比较null和undefined值
2016/05/16 Javascript
老生常谈 js中this的指向
2016/06/30 Javascript
AngularJS 实现JavaScript 动画效果详解
2016/09/08 Javascript
html中鼠标滚轮事件onmousewheel的处理方法
2016/11/11 Javascript
详解Jquery的事件操作和文档操作
2016/12/19 Javascript
php 修改密码实现代码
2017/05/24 Javascript
微信小程序 生命周期函数详解
2017/05/24 Javascript
利用vscode调试编译后的js代码详解
2018/05/14 Javascript
JavaScript中set与get方法用法示例
2018/08/15 Javascript
微信小程序文章详情页面实现代码
2018/09/10 Javascript
vue excel上传预览和table内容下载到excel文件中
2019/12/10 Javascript
javascript实现贪吃蛇经典游戏
2020/04/10 Javascript
如何在vue中使用jointjs过程解析
2020/05/29 Javascript
Python语言编写电脑时间自动同步小工具
2013/03/08 Python
Python中对元组和列表按条件进行排序的方法示例
2015/11/10 Python
python实现修改固定模式的字符串内容操作示例
2019/12/30 Python
pytorch中tensor张量数据类型的转化方式
2019/12/31 Python
python opencv 图像边框(填充)添加及图像混合的实现方法(末尾实现类似幻灯片渐变的效果)
2020/03/09 Python
First Aid Beauty官网:FAB急救面霜
2018/05/24 全球购物
营销专业应届生求职信
2013/11/26 职场文书
生物专业个人自荐信范文
2013/11/29 职场文书
公司新人试用期自我评价
2014/09/17 职场文书
2015学校年度工作总结
2015/05/11 职场文书