在指定时间后多次调用Javascript中的函数
Call a function in Javascript many times after a specified time
我想在指定的时间后调用一个无休止循环中的函数。由于某些原因,setIntervall不起作用。这里有一个小例子:
function button_clicked() {
clearInterval(interval)
interval = setInterval(test(), 1000);
}
var i=1;
function test(){
$("#body").append("<h1>Hi"+i+"</h1>");
i++;
}
只有当我点击按钮时(这个按钮开始button_clicked),它才会在输出中写入Hi和int,但不会在1秒之后。我做错了什么?
这不会像你想的那样:
setInterval(test(), 1000)
这会立即调用test
,并设置执行test
的返回值的间隔,即undefined
。
在JavaScript中,函数和其他函数一样都是变量。将变量(函数引用)传递给setInterval
,而不是执行函数:
setInterval(test, 1000)
setInterval
将function
作为第一个参数,但您没有正确传递它,请参阅:
interval = setInterval(test(), 1000);
替换为:
interval = setInterval(test, 1000);
删除setInterval中的括号。
在指定时间之后多次调用Javascript中的函数
否则,该函数将立即执行
相关文章:
- 创建一个类似链接的按钮,并通过Javascript函数打开一个新的弹出窗口
- 正在全局范围中查找JavaScript函数
- 如何将输入(type=text)从html表单传递到javascript函数
- 如何调用这个匿名 JavaScript 函数
- 通过Ajax将JavaScript函数传递给PHP文件
- 在javascript函数中设置全局变量
- 如何在执行此特定onclick事件时执行JavaScript函数
- 使用javascript函数在页面初始化后加载jquery
- javascript函数同步
- 如何将一个JavaScript函数回调为多个函数
- 在javascript函数中使用php变量
- 代码背后调用一个JavaScript函数的按钮点击-C#
- 将JavaScript函数与HTML分离
- 组合两个javascript函数
- 在 Java 中的 JavaScript 函数中插入 Wicket 值
- javascript函数内部的代码用逗号而不是分号分隔
- href属性内的javascript函数
- 使用html表单中的参数调用JavaScript函数
- 分析Javascript函数中的多个对象
- javascript函数的:和=之间的区别