javascript - 如何让 xmlHTTP 等待完成加载

标签 javascript xmlhttprequest

function updateItem(str)
{
    var stocks =new Array("GOOG","MSFT","AAP","JDAS","G");
    for(var i=0; i<stocks.length;i++)
    {

        xmlHttp=GetXmlHttpObject();    
        if (xmlHttp==null)
        {
            alert ("Browser does not support HTTP Request");
            return;
        }

        var url="php/updateCart.php";
        url=url+"?q="+stocks[i];
        url=url+"&sid="+Math.random();

        xmlHttp.onreadystatechange= function(){
            if (xmlHttp.readyState==4 || xmlHttp.readyState=="complete")
            {
                document.getElementById(stocks[i])
                .innerHTML=xmlHttp.responseText;
            }
        } 

        xmlHttp.open("GET",url,true);
        xmlHttp.send(null); 

    }
}    

function startOff()
{

    if(interval != -1)
    {
        clearInterval(interval);
    }

    interval = setInterval(function() {updateItem()}, 1000);
} 

我正在尝试在一个时间间隔内更新表单中的多个分区,问题是 for 循环会很快以完成请求。我没有意识到这一点,直到我发出了一堆警报,并注意到当我缓慢地按回车键时......我知道你也许可以使用 setTimeout 来做到这一点,但我似乎无法正确理解语法。由于我没有用于检查就绪状态的函数的名称,有人可以给我有关语法的提示。或者如果有更简单的方法......我将不胜感激。

最佳答案

编辑:我把事情搞混了,认为 javascript 具有 block 作用域。我想,当你尝试用多种语言解决问题时,就会发生这种情况。问题仍然是一样的,但解决方案却不同。我仍然不会使用您使用的超时来解决这个问题(或者在前一个请求完成后开始下一个请求),因为我认为这不是正确的方法。相反,我将解决超时技术只是试图解决的根本问题。

问题不在于 for 循环“太快”。问题是您在回调函数中使用的变量的范围大于 for 循环体。这意味着您每次将相同的变量设置为不同的值。这样,当最终调用回调函数时,变量将具有最终值。

解决此问题的一种方法是将请求的创建移至新函数,如下所示:

function updateAllItems()
{
    var stocks =new Array("GOOG","MSFT","AAP","JDAS","G");
    for(var i=0; i<stocks.length;i++)
    {
        updateItem(stocks[i]);
    }
}

function updateItem(stock)
{
    var xmlHttp=GetXmlHttpObject(); // Do note, we need the var keyword here to
                                    // make sure this variables uses this scope
                                    // rather than global scope
    if (xmlHttp==null)
    {
        alert ("Browser does not support HTTP Request");
        return;
    }

    var url="php/updateCart.php";
    url=url+"?q="+ stock;
    url=url+"&sid="+Math.random();

    xmlHttp.onreadystatechange= function(){
        if (xmlHttp.readyState==4 || xmlHttp.readyState=="complete")
        {
            document.getElementById(stock)
            .innerHTML=xmlHttp.responseText;
        }
    }

    xmlHttp.open("GET",url,true);
    xmlHttp.send(null);
}

这可能是更容易理解的方式,但我个人更喜欢下面的方式。它基本上做同样的事情,但是使用一些 Javascript 技巧和我们立即调用的匿名函数,我们不再需要像这样的单独函数,而是可以处理这个内联:

function updateAllItems()
{
    var stocks =new Array("GOOG","MSFT","AAP","JDAS","G");
    for(var i=0; i<stocks.length;i++)
    {

        (function ()
        {
            var xmlHttp=GetXmlHttpObject(); // Do note, we need the var keyword here to
                                            // make sure this variables uses this scope
                                            // rather than global scope
            var i2 = i;

            if (xmlHttp==null)
            {
                alert ("Browser does not support HTTP Request");
                return;
            }

            var url="php/updateCart.php";
            url=url+"?q="+ stocks[i];
            url=url+"&sid="+Math.random();

            xmlHttp.onreadystatechange= function(){
                if (xmlHttp.readyState==4 || xmlHttp.readyState=="complete")
                {
                    document.getElementById(stocks[i])
                         .innerHTML=xmlHttp.responseText;
                }
            }
        })();

        xmlHttp.open("GET",url,true);
        xmlHttp.send(null);
    }
}

关于javascript - 如何让 xmlHTTP 等待完成加载,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13293321/

相关文章:

javascript - 使用 jquery deferred and then 了解顺序异步操作的链接

javascript - Ionic2:如何包含信号器?

javascript - jQuery bind() - 如果 LI 单击事件触发,则防止触发 HTML 单击事件

javascript - Javascript 中如何创建、合并和销毁 xmlhttprequest 对象

javascript - 使用 Javascript 确定文件是否存在(本地)

javascript - 使用 XMLHTTP JavaScript 通过 cURL PHP 接收参数

javascript - CORS 'Allow-Credentials' Node/ express

JavaScript 对象属性为 "sometimes"未定义

xml - XMLHttpRequest的Open方法

javascript - 在 IE 中折叠 tr 时表格中不需要的行