博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
js for循环 ajax
阅读量:4335 次
发布时间:2019-06-07

本文共 2845 字,大约阅读时间需要 9 分钟。

首先说,出现这个问题的场景是很少见的,因为有太多更好解决方法。今天搞ajax的时候,一个有趣的地方,,每个迭代中都要发送一个get请求,因为迭代的速度太快,一个请求还没有完成就进行下一个迭代,在chrome和ff上,除最后一个请求外,其它请求都被取消了。所以该怎么办呢?设置延时(不太好)还是其他办法?

 办法有很多,比如设置休眠,迭代等等, 我采用的是另外两种解决办法。
 一、同步的ajax请求,而ajax请求默认是异步的,所以要设置为false。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
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请求,就会等服务器响应后,执行完代码,再继续迭代。但是好像不推荐这样做。

二、采用异步的方式,但要记住,每次迭代都要创建一个新XMLHttpRequest对象,不能重用。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
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请求,似乎同步的方式性能更高。

这个问题解决了,也加深了对ajax、http的理解。

以上就介绍了JavaScript for循环中发送AJAX请求的问题,希望对Javascript教程有兴趣的朋友有所帮助。

转载于:https://www.cnblogs.com/isWhile/p/11131226.html

你可能感兴趣的文章
小D课堂 - 零基础入门SpringBoot2.X到实战_第10节 SpringBoot整合定时任务和异步任务处理_42、SpringBoot常用定时任务配置实战...
查看>>
小D课堂 - 零基础入门SpringBoot2.X到实战_第9节 SpringBoot2.x整合Redis实战_39、SpringBoot2.x整合redis实战讲解...
查看>>
小D课堂 - 零基础入门SpringBoot2.X到实战_第14节 高级篇幅之SpringBoot多环境配置_59、SpringBoot多环境配置介绍和项目实战...
查看>>
小D课堂 - 零基础入门SpringBoot2.X到实战_第10节 SpringBoot整合定时任务和异步任务处理_41、SpringBoot定时任务schedule讲解...
查看>>
小D课堂 - 零基础入门SpringBoot2.X到实战_第10节 SpringBoot整合定时任务和异步任务处理_43、SpringBoot2.x异步任务实战(核心知识)...
查看>>
小D课堂 - 新版本微服务springcloud+Docker教程_1_01课程简介
查看>>
小D课堂 - 零基础入门SpringBoot2.X到实战_第11节 Logback日志框架介绍和SpringBoot整合实战_45、SpringBoot2.x日志讲解和Logback配置实战...
查看>>
小D课堂 - 新版本微服务springcloud+Docker教程_1_02技术选型
查看>>
小D课堂 - 新版本微服务springcloud+Docker教程_汇总
查看>>
小D课堂 - 新版本微服务springcloud+Docker教程_2_01传统架构演进到分布式架构
查看>>
小D课堂 - 新版本微服务springcloud+Docker教程_2_02 微服务核心基础讲解
查看>>
小D课堂 - 新版本微服务springcloud+Docker教程_2_04微服务下电商项目基础模块设计...
查看>>
小D课堂 - 新版本微服务springcloud+Docker教程_3-01 什么是微服务的注册中心
查看>>
小D课堂 - 新版本微服务springcloud+Docker教程_3-03CAP原理、常见面试题
查看>>
小D课堂 - 新版本微服务springcloud+Docker教程_3-05 服务注册和发现Eureka Server搭建实战...
查看>>
小D课堂 - 新版本微服务springcloud+Docker教程_3-06 服务注册和发现之Eureka Client搭建商品服务实战...
查看>>
小D课堂 - 新版本微服务springcloud+Docker教程_3-07 Eureka服务注册中心配置控制台问题处理...
查看>>
小D课堂 - 新版本微服务springcloud+Docker教程_4-03 高级篇幅之Ribbon负载均衡源码分析实战...
查看>>
小D课堂 - 新版本微服务springcloud+Docker教程_4-05 微服务调用方式之feign 实战 订单调用商品服务...
查看>>
小D课堂 - 新版本微服务springcloud+Docker教程_5-02 Netflix开源组件断路器
查看>>