详解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 相关文章推荐
ExtJs中简单的登录界面制作方法
Aug 19 Javascript
IE不支持getElementsByClassName最终完美解决方案
Dec 17 Javascript
window resize和scroll事件的基本优化思路
Apr 29 Javascript
javascript实现的简单计时器
Jul 19 Javascript
浅谈node.js中async异步编程
Oct 22 Javascript
JS提交form表单实例分析
Dec 10 Javascript
基于JavaScript实现添加到购物车效果附源码下载
Aug 22 Javascript
基于javascript实现的快速排序
Dec 02 Javascript
VUE实现一个分页组件的示例
Sep 13 Javascript
jQuery使用zTree插件实现可拖拽的树示例
Sep 23 jQuery
用JavaScript做简易的购物车的代码示例
Oct 20 Javascript
vue界面发送表情的实现代码
Sep 11 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
怎么使 Mysql 数据同步
2006/10/09 PHP
PHP实现简单汉字验证码
2015/07/28 PHP
php+ajax无刷新上传图片实例代码
2015/11/17 PHP
ThinkPHP 模板引擎使用详解
2017/05/07 PHP
php微信扫码支付 php公众号支付
2019/03/24 PHP
JavaScript和JQuery实用代码片段(一)
2010/04/07 Javascript
让图片旋转任意角度及JQuery插件使用介绍
2013/03/20 Javascript
简略说明Javascript中的= =(等于)与= = =(全等于)区别
2013/04/16 Javascript
js获取事件源及触发该事件的对象
2013/10/24 Javascript
javascript弹出层输入框(示例代码)
2013/12/11 Javascript
JavaScript动态加载样式表的方法
2015/03/21 Javascript
浅谈JavaScript中的字符编码转换问题
2015/07/07 Javascript
Bootstrap表单布局样式代码
2016/05/31 Javascript
AngularJS入门教程之 XMLHttpRequest实例讲解
2016/07/27 Javascript
常用js,css文件统一加载方法(推荐) 并在加载之后调用回调函数
2016/09/23 Javascript
动态加载权限管理模块中的Vue组件
2018/01/16 Javascript
ES6中定义类和对象的方法示例
2019/07/31 Javascript
Python多进程编程技术实例分析
2014/09/16 Python
在类Unix系统上开始Python3编程入门
2015/08/20 Python
Python实现树的先序、中序、后序排序算法示例
2017/06/23 Python
Ubuntu16.04/树莓派Python3+opencv配置教程(分享)
2018/04/02 Python
python操作文件的参数整理
2019/06/11 Python
python如何从文件读取数据及解析
2019/09/19 Python
Python Django中间件,中间件函数,全局异常处理操作示例
2019/11/08 Python
关于Pytorch MaxUnpool2d中size操作方式
2020/01/03 Python
Pandas时间序列:时期(period)及其算术运算详解
2020/02/25 Python
Python用5行代码实现批量抠图的示例代码
2020/04/14 Python
使用 css3 transform 属性来变换背景图的方法
2019/05/07 HTML / CSS
纯HTML5+CSS3制作图片旋转
2016/01/12 HTML / CSS
英国标准协会商店:BSI Shop
2019/02/25 全球购物
美国沙龙美发产品购物网站:Hair.com by L’Oreal
2020/11/09 全球购物
自我鉴定标准格式
2014/03/19 职场文书
电子信息工程专业求职信
2014/06/28 职场文书
原告代理词范文
2015/05/25 职场文书
新员工试用期工作总结2015
2015/05/28 职场文书
基层医务人员三严三实心得体会
2016/01/05 职场文书