问题描述:
你好!
我的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变量.
基本上,您不应该信任回调函数来正确执行自身-它会卡住很多次!