PHP   发布时间:2022-04-04  发布网站:大佬教程  code.js-code.com
大佬教程收集整理的这篇文章主要介绍了php-在ajax readystate()中没有alert()的情况下循环不起作用大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。

问题描述:
你好!

我的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闭包的信息,并且它确实可以使执行/渲染保持同步

解决办法是什么?

解决方法:

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

但是,如果没有alert(),您的代码只会检查一次readyState变量

一种解决方法是通过在调用中将异步参数设置为false来使调用同步.不利的一面是客户端将冻结直到收到AJAX响应.

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

基本上,您不应该信任回调函数来正确执行自身-它会卡住很多次!

大佬总结

以上是大佬教程为你收集整理的php-在ajax readystate()中没有alert()的情况下循环不起作用全部内容,希望文章能够帮你解决php-在ajax readystate()中没有alert()的情况下循环不起作用所遇到的程序开发问题。

如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。
标签: