没有alert()在ajax readystate()中循环不起作用

时间:2009-10-22 12:57:12

标签: php ajax variables local

问题描述: 您好!

我的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闭包的事情,以及它有助于执行/呈现同步的事实

解决方案是什么?

1 个答案:

答案 0 :(得分:3)

好的,这种情况正在发生,因为您没有轮询onreadystatechange函数。基本上,调用是异步的,您需要每隔几毫秒轮询一次readyState变量,以查看它何时发生变化。这就是它使用alert()的原因 - 警报导致长时间停顿,在此期间客户端收到AJAX响应。在警报获得响应并且代码根据需要执行后,将检查readyState变量。

但是,如果没有alert(),您的代码只需

检查readyState变量

一种方法是通过在调用中将异步参数设置为false来使调用同步。这有一个缺点,客户端将冻结,直到收到AJAX响应。

另一种方法是继续轮询readyState变量。

基本上,你不应该相信回调函数能够正确执行它 - 它会多次卡住!