zoukankan      html  css  js  c++  java
  • setTimeout()和setInterval()方法的区别?

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

    }

  • 相关阅读:
    JavaScript Array 对象方法
    前后台如何转码
    nrm 的使用说明
    sass的学习笔记
    前端书籍概述;
    程序员必读书籍及导读指南
    HTML5之FileReader的使用
    jQery的方法
    jQuery的使用说明
    div,contenteditable编辑器之ctrl+enter换行,enter发送
  • 原文地址:https://www.cnblogs.com/lzghyh/p/12164840.html
Copyright © 2011-2022 走看看