详解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与vbscript数据共享
Jan 09 Javascript
document.open() 与 document.write()的区别
Aug 13 Javascript
JS 文件大小判断的实现代码
Apr 07 Javascript
JavaScript打字小游戏代码
Dec 26 Javascript
CSS3 3D 技术手把手教你玩转
Sep 02 Javascript
JavaScript学习笔记整理_简单实现枚举类型,扑克牌应用
Sep 19 Javascript
Javascript中字符串replace方法的第二个参数探究
Dec 05 Javascript
详解本地Node.js服务器作为api服务器的解决办法
Feb 28 Javascript
浅谈node.js 命令行工具(cli)
May 10 Javascript
在vue中多次调用同一个定义全局变量的实例
Sep 25 Javascript
JavaScript变量提升和严格模式实例分析
Jan 27 Javascript
过滤器vue.filters的使用方法实现
Sep 18 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的preg_match匹配字符串长度问题解决方法
2014/05/03 PHP
PHP生成随机密码类分享
2014/06/25 PHP
PHP生成唯一订单号
2015/07/05 PHP
PHP异常处理Exception类
2015/12/11 PHP
FireFox JavaScript全局Event对象
2009/06/14 Javascript
JavaScript入门之对象与JSON详解
2011/10/21 Javascript
讲解JavaScript中for...in语句的使用方法
2015/06/03 Javascript
JS简单实现DIV相对于浏览器固定位置不变的方法
2016/06/17 Javascript
详解AngularJS如何实现跨域请求
2016/08/22 Javascript
简单理解js的冒泡排序
2016/12/19 Javascript
JavaScript自定义分页样式
2017/01/17 Javascript
浅谈angularjs依赖服务注入写法的注意点
2017/04/24 Javascript
详解vue-cli项目中用json-sever搭建mock服务器
2017/11/02 Javascript
javaScript 连接打印机,打印小票的实例
2017/12/29 Javascript
JavaScript实现求最大公共子串的方法
2018/02/03 Javascript
vue动画之点击按钮往上渐渐显示出来的实例
2018/09/29 Javascript
angular使用md5,CryptoJS des加密的方法
2019/06/03 Javascript
Webpack按需加载打包chunk命名的方法
2019/09/22 Javascript
用Python编程实现语音控制电脑
2014/04/01 Python
Python内置函数delattr的具体用法
2017/11/23 Python
用十张图详解TensorFlow数据读取机制(附代码)
2018/02/06 Python
windows下pycharm安装、创建文件、配置默认模板
2018/07/31 Python
基于python分析你的上网行为 看看你平时上网都在干嘛
2019/08/13 Python
python数值基础知识浅析
2019/11/19 Python
Python3打包exe代码2种方法实例解析
2020/02/17 Python
如何将anaconda安装配置的mmdetection环境离线拷贝到另一台电脑
2020/10/15 Python
Numpy ndarray 多维数组对象的使用
2021/02/10 Python
html5指南-5.使用web storage存储键值对的数据
2013/01/07 HTML / CSS
韩都衣舍天猫官方旗舰店:天猫女装销售总冠军
2017/10/10 全球购物
倩碧英国官网:Clinique英国
2018/08/10 全球购物
电子商务专业学生的学习自我评价
2013/10/27 职场文书
毕业实习评语
2014/02/10 职场文书
2015年医生个人工作总结
2015/04/25 职场文书
2015年学校精神文明工作总结
2015/05/27 职场文书
2016年青少年禁毒宣传教育活动总结(学校)
2016/04/05 职场文书
如何使用SQL Server语句创建表
2022/04/12 SQL Server