问题描述: 您好!
我的XMLHTTPRequest对象在准备好后会做一些事情。我收到的responseText被拆分,并作为参数发送给myFunction()
。
现在,我需要多次调用myFunction()
'n',并将响应文本的子字符串作为参数。
此作品:
myAjaxObj.onreadystatechange=function()
{
if(myAjaxObj.readyState==4)
{
if(myAjaxObj.status==200)
{
myFunction( myAjaxObj.responseText, id )
这不起作用:
myAjaxObj.onreadystatechange=function()
{
if(myAjaxObj.readyState==4)
{
if(myAjaxObj.status==200)
{
var count i=0;
for( i=0; i < 5; i++ )
{
[b]alert("Without this it wont work") [/b]
myFunction( myAjaxObj.responseText, i );
}
基本上,除非取消注释alert(),否则for循环中的代码将不会运行。 我已经阅读了关于javascript闭包的事情,以及它有助于执行/呈现同步的事实
解决方案是什么?
答案 0 :(得分:3)
好的,这种情况正在发生,因为您没有轮询onreadystatechange函数。基本上,调用是异步的,您需要每隔几毫秒轮询一次readyState变量,以查看它何时发生变化。这就是它使用alert()的原因 - 警报导致长时间停顿,在此期间客户端收到AJAX响应。在警报获得响应并且代码根据需要执行后,将检查readyState变量。
但是,如果没有alert(),您的代码只需
检查readyState变量一种方法是通过在调用中将异步参数设置为false来使调用同步。这有一个缺点,客户端将冻结,直到收到AJAX响应。
另一种方法是继续轮询readyState变量。
基本上,你不应该相信回调函数能够正确执行它 - 它会多次卡住!