详解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 相关文章推荐
alixixi runcode.asp的代码不错的应用
Aug 08 Javascript
jQuery 验证插件 Web前端设计模式(asp.net)
Oct 17 Javascript
js中各浏览器中鼠标按键值的差异
Apr 07 Javascript
jQuery中outerHeight()方法用法实例
Jan 19 Javascript
ECMAScript6中Set/WeakSet详解
Jun 12 Javascript
jquery简单实现幻灯片的方法
Aug 03 Javascript
微信小程序 定位到当前城市实现实例代码
Feb 23 Javascript
jquery.uploadifive插件怎么解决上传限制图片或文件大小问题
May 08 jQuery
AngularJS ng-repeat指令及Ajax的应用实例分析
Jul 06 Javascript
微信小程序左右滑动的实现代码
Dec 15 Javascript
详解如何在vue项目中使用lodop打印插件
Sep 27 Javascript
浅析JS中什么是自定义react数据验证组件
Oct 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 flush无效,IIS7下php实时输出的方法
2016/08/25 PHP
PDO::commit讲解
2019/01/27 PHP
PHP与Web页面的交互示例详解二
2020/08/04 PHP
Json对象与Json字符串互转(4种转换方式)
2013/03/27 Javascript
解析javascript 浏览器关闭事件
2013/07/08 Javascript
JavaScript字符串常用类使用方法汇总
2015/04/14 Javascript
Bootstrap学习笔记之js组件(4)
2016/06/12 Javascript
基于NodeJS+MongoDB+AngularJS+Bootstrap开发书店案例分析
2017/01/12 NodeJs
EasyUI修改DateBox和DateTimeBox的默认日期格式示例
2017/01/18 Javascript
vue.js国际化 vue-i18n插件的使用详解
2017/07/07 Javascript
nodejs搭建本地服务器轻松解决跨域问题
2018/03/21 NodeJs
Vue实现todolist删除功能
2018/06/26 Javascript
JavaScript 对引擎、运行时、调用堆栈的概述理解
2018/10/22 Javascript
vue中js判断长时间不操作界面自动退出登录(推荐)
2020/01/22 Javascript
Node 使用express-http-proxy 做api网关的实现
2020/10/15 Javascript
Antd-vue Table组件添加Click事件,实现点击某行数据教程
2020/11/17 Javascript
Vue项目中使用mock.js的完整步骤
2021/01/12 Vue.js
简明 Python 基础学习教程
2007/02/08 Python
Python利用字典将两个通讯录文本合并为一个文本实例
2018/01/16 Python
Python 16进制与中文相互转换的实现方法
2018/07/09 Python
对Python中Iterator和Iterable的区别详解
2018/10/18 Python
Python日期时间Time模块实例详解
2019/04/15 Python
如何基于Python批量下载音乐
2019/11/11 Python
基于Python中isfile函数和isdir函数使用详解
2019/11/29 Python
python3发送request请求及查看返回结果实例
2020/04/30 Python
基于Python下载网络图片方法汇总代码实例
2020/06/24 Python
澳大利亚首屈一指的在线购物目的地:Kogan.com
2017/02/02 全球购物
美国羊皮公司:Overland
2018/01/15 全球购物
个人借款担保书
2014/04/02 职场文书
新学期国旗下演讲稿
2014/05/08 职场文书
入职担保书范文
2014/05/21 职场文书
《改造我们的学习》心得体会
2014/11/07 职场文书
新员工入职欢迎词
2015/01/23 职场文书
Jupyter notebook 更改文件打开的默认路径操作
2021/05/21 Python
python unittest单元测试的步骤分析
2021/08/02 Python
HTML页面点击按钮关闭页面的多种方式
2022/12/24 HTML / CSS