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);

}

posted on 2020-01-08 09:20  幂次方  阅读(4302)  评论(0编辑  收藏  举报