php中alert不起作用,php-在ajax readystate()中没有alert()的情况下循环不起作用
问题描述:你好!我的XMLHTTPRequest对象准备就绪后,会做几件事.我收到的responseText被拆分,并作为参数发送到myFunction().现在,我需要使用响应文本的子字符串作为参数,多次调用myFunction()’n’.这有效:myAjaxObj.onreadystatechange=function(){if(myAjaxObj.readyState==4){if(myAj
问题描述:
你好!
我的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变量.
基本上,您不应该信任回调函数来正确执行自身-它会卡住很多次!
标签:variables,ajax,local,php
来源: https://codeday.me/bug/20191210/2101754.html
魔乐社区(Modelers.cn) 是一个中立、公益的人工智能社区,提供人工智能工具、模型、数据的托管、展示与应用协同服务,为人工智能开发及爱好者搭建开放的学习交流平台。社区通过理事会方式运作,由全产业链共同建设、共同运营、共同享有,推动国产AI生态繁荣发展。
更多推荐


所有评论(0)