繁体   English   中英

IE8问题与javascript函数在setTimeout中调用自身

[英]IE8 problem with javascript function that calls itself in setTimeout

我有一个在JavaScript中定义的定位函数

var locID;

function locateMe()
{
    if(locID > 0)
    {
        // i do a jquery post here
    }

    setTimeout(locateMe, 2000);
} 

// my document ready function is here, and inside it, at the end of it
// i do this
locID = 0;
locateMe();

当我在firefox中测试此代码时,每两秒调用一次locateMe函数并按预期工作。 当我在IE8中测试代码时,函数永远不会被调用(至少它看起来永远不会被我使用IE的开发人员工具看到)

注意:在“zone_row”类的click事件处理程序中定义了修改locID的代码。 再次,在Firefox中一切都按预期工作。 奇怪的是,在IE中点击zone_row时,函数将被称为ONCE。 我可以看到开发人员工具和jquery帖子的操作结果。

我认为IE中只有一些我不熟悉的异常情况。 我究竟做错了什么?

编辑:更改“locateMe();” 在setTimeout调用中定位Me。

更新:添加更多我的代码(在评论中的每个请求)以显示位置(尽管代码不比我的第一篇文章多)。

<script type="text/javascript">
    var z_items;
    var locID;

    function locateMe()
    {
            if(locID > 0)
            {
                    // my jquery post is here                   
            }   

            setTimeout(locateMe, 2000);
    }

    $(document).ready(function()
    {
            // ... some click events and get requests here ...

            locID = 0;
            locateMe();
    });
</script>

我也尝试在setTimeout中包装调用(没有效果)并更改DOCTYPE(这实际上导致IE从不调用函数,而不是现在它称之为ONCE并且再也不会)。

问题解决了。 我找到了这个帖子中我遇到的另一个问题的答案:

防止浏览器缓存jQuery AJAX调用结果

添加$ .ajaxSetup({cache:false}); 对于我的文档就绪功能,它也解决了这个问题。 它看起来像是一个缓存问题。

我发现,对于IE(甚至是IE9),如果你将自调用函数嵌套在一个匿名函数中,它就可以工作。 但看起来Toddeman的问题确实与ajax部分有关。

所以代码是:

function locateMe()
{
    /* ... */   

    //IE way (still works in Chrome and FF):
    setTimeout(function () { locateMe(); }, 2000);

    //original: setTimeout(locateMe, 2000);
}

使用

setTimeout( locateMe, 2000 );

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM