详解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 相关文章推荐
jquery 全局AJAX事件使用代码
Nov 05 Javascript
jQuery实战之仿淘宝商城左侧导航效果
Apr 12 Javascript
JS中对象与字符串的互相转换详解
May 20 Javascript
JavaScript Base64 作为文件上传的实例代码解析
Feb 14 Javascript
使用Bootrap和Vue实现仿百度搜索功能
Oct 26 Javascript
用React实现一个完整的TodoList的示例代码
Oct 30 Javascript
在vue项目中,使用axios跨域处理
Mar 07 Javascript
Angular5集成eventbus的示例代码
Jul 19 Javascript
微信小程序使用websocket通讯的demo,含前后端代码,亲测可用
May 22 Javascript
详解Vue项目引入CreateJS的方法(亲测可用)
May 30 Javascript
微信小程序前端自定义分享的实现方法
Jun 13 Javascript
element el-table表格的二次封装实现(附表格高度自适应)
Jan 19 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函数指定默认值方法的小例子
2013/12/04 PHP
php通过sort()函数给数组排序的方法
2015/03/18 PHP
Laravel4中的Validator验证扩展用法详解
2016/07/26 PHP
PHP未登录自动跳转到登录页面
2016/12/21 PHP
学习YUI.Ext 第三天
2007/03/10 Javascript
大家未必知道的Js技巧收藏
2008/04/07 Javascript
JS+CSS实现可拖动的弹出提示框
2015/02/16 Javascript
JavaScript位置与大小(1)之正确理解和运用与尺寸大小相关的DOM属性
2015/12/26 Javascript
jQuery插件实现可输入和自动匹配的下拉框
2016/10/24 Javascript
Vuex之理解state的用法实例
2017/04/19 Javascript
详解vue静态资源打包中的坑与解决方案
2018/02/05 Javascript
150行Node.js实现的dns代理工具
2019/08/02 Javascript
基于javascript处理nginx请求过程详解
2020/07/07 Javascript
webstorm建立vue-cli脚手架的傻瓜式教程
2020/09/22 Javascript
python实现多线程的方式及多条命令并发执行
2016/06/07 Python
Python简单的制作图片验证码实例
2017/05/31 Python
聊聊Python中的pypy
2018/01/12 Python
Python实现针对给定单链表删除指定节点的方法
2018/04/12 Python
python 读文件,然后转化为矩阵的实例
2018/04/23 Python
详解python 模拟豆瓣登录(豆瓣6.0)
2019/04/18 Python
pandas取出重复数据的方法
2019/07/04 Python
python 利用已有Ner模型进行数据清洗合并代码
2019/12/24 Python
python pyecharts 实现一个文件绘制多张图
2020/05/13 Python
pandas dataframe 中的explode函数用法详解
2020/05/18 Python
TensorFlow固化模型的实现操作
2020/05/26 Python
一些关于python 装饰器的个人理解
2020/08/31 Python
python 常用日期处理-- datetime 模块的使用
2020/09/02 Python
RetroStage德国:复古服装
2019/02/03 全球购物
在浏览器端如何得到服务器端响应的XML数据
2012/11/24 面试题
市场营销专业毕业生求职信
2014/03/26 职场文书
《风娃娃》教学反思
2014/04/19 职场文书
文明礼仪伴我行演讲稿
2014/05/12 职场文书
党的群众路线教育实践活动整改方案
2014/10/28 职场文书
python 自动化偷懒的四个实用操作
2021/04/11 Python
Python如何用re模块实现简易tokenizer
2022/05/02 Python
GO中sync包自由控制并发示例详解
2022/08/05 Golang