SetInterval一直在调用相同的函数
SetInterval keeps calling same function
我有这个函数:
original = 0;
original = original+1;
setInterval("dis"+original+"();", 2400);
但有一个问题,每次调用它时,它似乎都在再次调用同一个函数。。。它们不调用单独的函数。
谢谢你的帮助。
每次都需要重新生成函数名,因为setInterval不会帮你处理这个问题——它总是运行设置时传递给它的代码。
这将在全局范围(window
)中找到正确的函数,并将其称为:
original = 0;
original = original+1;
setInterval(function(){
window["dis" + original]();
original++;
}, 2400);
计数器的递增也需要在setInterval处理程序中完成。
这是因为original
用于构造回调函数名一次,并且仅用于构造一次,以调用setInterval
。顾名思义,setInterval
设置一次回调并继续执行,直到用clearInterval
清除间隔。
如果您想更改要调用的方法,可以尝试setTimeout
,即:
var original = 0,
cb = function() {
('dis' + original).prototype.call(null);
original++;
setTimeout(cb, 2400);
}
cb();
相关文章:
- 是否可以将一个函数输入连接到另一个函数调用的文本
- 在输入字段上有两个函数调用,一个在Blur上,一个不在Angular中
- 如何在Javascript函数调用中循环变量
- Javascript:应为赋值或函数调用,但实际看到的却是表达式
- 如何远程检查JavaScript应用程序的函数调用堆栈
- javascript函数调用不起作用
- 为什么这个函数调用会破坏程序并导致未定义的变量
- 如何通过函数调用设置图像的src
- 从全局函数调用Ember控制器上的方法
- 为什么Jquery$.ajax在函数调用中触发所有statusCode,即使调用成功
- JavaScript函数调用(arg1)(arg2)
- 打印链接时,将javascript函数调用到链接中
- 在函数调用中封装数据除了隐藏数据之外还有什么优点
- 无法从JavaScript中的函数调用对象属性
- 对中的函数调用进行排序是回调的唯一方法
- 函数调用方法有什么用
- Javascript:JSHint:应为赋值或函数调用,但实际看到的却是表达式
- HTML5(Bootstrap)通过函数调用运行动画
- 函数调用不起作用
- 函数中的Javascript函数调用