gpt4 book ai didi

javascript - 新闻代码 : Recursion Error

转载 作者:行者123 更新时间:2023-12-01 05:49:29 25 4
gpt4 key购买 nike

我试图为我正在创建的网站实现一个简单的新闻行情。作为 JS 和 JQuery 的新手,我从网站上获取了代码。该代码工作得很好,但是当我转移函数调用时,会发生太多递归(firefox)错误。原函数:

$(document).ready(function(){
var tick=function()
{
window.setTimeout(function()
{
$('#ticker li:first').animate({marginTop:"-30px"},700,function()
{
$(this).detach().appendTo('#ticker').removeAttr('style');
});
tick();//Old position for function call- works fine
},4000);
};
tick();
});

上面的代码有效,但是当我将递归调用转移到 setTimeout 函数之外时,会出现递归错误。稍微修改一下代码:

$(document).ready(function(){
var tick=function()
{
window.setTimeout(function()
{
$('#ticker li:first').animate({marginTop:"-30px"},700,function()
{
$(this).detach().appendTo('#ticker').removeAttr('style');
});

},4000);
tick();//New position for function call-leads to unresponsive page
};
tick();
});

我的问题是:上面的代码不应该以完全相同的方式工作吗?当位置改变时,什么会发生变化?

最佳答案

the setTimeout function的目的是设置另一个函数在指定的时间后运行。但是,超时运行不会阻止其他代码执行 - setTimeout 函数仅设置超时,它会立即执行,而不是等待传递给它的函数实际运行。当您在 setTimeout 函数调用中调用 tick() 且超时时间为 4000 毫秒时,您将获得重新运行 tick() 的效果> 每四秒一次。但是,一旦您将其移出 setTimeout 调用,它就会在您第一次调用它时立即无限地重新运行。

关于javascript - 新闻代码 : Recursion Error,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23742876/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com