问题描述:
你好!
我的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变量.
基本上,您不应该信任回调函数来正确执行自身-它会卡住很多次!
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。