详解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学习笔记1 数据类型
Jan 11 Javascript
javascript中用星号表示预录入内容的实现代码
Jan 08 Javascript
javascript表格隔行变色加鼠标移入移出及点击效果的方法
Apr 10 Javascript
jQuery mobile 移动web(6)
Dec 20 Javascript
JavaScript中各种引用类型的常用操作方法小结
May 05 Javascript
用原生js统计文本行数的简单示例
Aug 19 Javascript
JS实现上传图片的三种方法并实现预览图片功能
Jul 14 Javascript
JS实现移动端整屏滑动的实例代码
Nov 10 Javascript
node结合swig渲染摸板的方法
Apr 11 Javascript
解决element UI 自定义传参的问题
Aug 22 Javascript
ElementUI 修改默认样式的几种办法(小结)
Jul 29 Javascript
vue elementui tree 任意级别拖拽功能代码
Aug 31 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 面向对象详解
2012/09/13 PHP
php中检查文件或目录是否存在的代码小结
2012/10/22 PHP
thinkphp的c方法使用示例
2014/02/24 PHP
php支持断点续传、分块下载的类
2016/05/02 PHP
javascript比较文档位置
2008/04/08 Javascript
js实现动态添加、删除行、onkeyup表格求和示例
2013/08/18 Javascript
JS图像无缝滚动脚本非常好用
2014/02/10 Javascript
js实现图片漂浮效果的方法
2015/03/02 Javascript
使用Jquery实现每日签到功能
2015/04/03 Javascript
jQuery子窗体取得父窗体元素的方法
2015/05/11 Javascript
JS动态创建元素的两种方法
2016/04/20 Javascript
jQuery基础知识点总结(必看)
2016/05/31 Javascript
JavaScript实现url参数转成json形式
2016/09/25 Javascript
jQGrid动态填充select下拉框的选项值(动态填充)
2016/11/28 Javascript
Vue.js第三天学习笔记(计算属性computed)
2016/12/01 Javascript
jquery UI Datepicker时间控件冲突问题解决
2016/12/16 Javascript
浅谈angular4.0中路由传递参数、获取参数最nice的写法
2018/03/12 Javascript
微信小程序wx.request拦截器使用详解
2019/07/09 Javascript
layui table 获取分页 limit的方法
2019/09/20 Javascript
[02:29]大剑、皮鞭、女装,这届DOTA2勇士令状里都有
2020/07/17 DOTA
Python实现配置文件备份的方法
2015/07/30 Python
Python机器学习k-近邻算法(K Nearest Neighbor)实例详解
2018/06/25 Python
解决Python中定时任务线程无法自动退出的问题
2019/02/18 Python
用scikit-learn和pandas学习线性回归的方法
2019/06/21 Python
python实现将视频按帧读取到自定义目录
2019/12/10 Python
Python enumerate函数遍历数据对象组合过程解析
2019/12/11 Python
Solid & Striped官网:美国泳装品牌
2019/06/19 全球购物
奥地利购买珠宝和手表网站:ELLA JUWELEN
2019/09/03 全球购物
英国高街奥特莱斯:Highstreet Outlet
2019/11/21 全球购物
BannerBuzz加拿大:在线定制横幅印刷、广告和标志
2020/03/10 全球购物
物理教师自荐信范文
2013/12/28 职场文书
超市端午节活动方案
2014/01/23 职场文书
2014年信息中心工作总结
2014/12/17 职场文书
土木工程毕业答辩开场白
2015/05/29 职场文书
男人帮观后感
2015/06/18 职场文书
CSS SandBox应用场景及常见问题
2022/06/25 HTML / CSS