setTimeout(表达式,延时时间):
在执行时,是在载入执行一次后延迟指定时间后,再执行一次表达式,需要函数触发;被动触发
setInterval(表达式,交互时间):
它从载入后,立即进入计算状态,每隔指定的时间就执行一次表达式;主动触发
将setTimeout包含于被执行函数中,然后在函数外再次使用setTimeout来达到定时执行的目的(类似于递归),函数外的setTimeout在执行函数时再次触发setTimeout从而形成周而复始的定时效果,
使用的时候各有各的优势,使用setInterval,需要手动的停止tick触发。而使用方法中嵌套setTimeout,可以根据方法内部本身的逻辑不再调用setTimeout就等于停止了触发。
其实两个东西完全可以相互模拟,具体使用那个,看当时的需要而定了。就像for可以模拟所有的循环包括分支,而还提供了do、while一样。
例如:
如果方法需要参数,则该方法需要用引号括起来,否则不需要
//60秒后执行myFunction()一次
setInterval("myFunction()",60000);
funcition myFunction(){
alert(’myFunction()’);
}
如果方法需要参数,则该方法需要用引号括起来,否则不需要
例如带参数:
function attachmentUpload(fileCount,itemType, assessId, projectStatus,alertMessage)
{
setTimeout('attachmentUpload('+fileCount+','+itemType+',\"'+ assessId+ '\",'+ projectStatus+',\"'+alertMessage+'\")',60000);
}
例如不带参数:
function attachmentUpload()
{
setTimeout(attachmentUpload,60000);
}