javascript setTimeout和setInterval计时的区别详解


Posted in Javascript onJune 21, 2013

setTimeout方法是定时程序,也就是在什么时间以后干什么。干完了就拉倒。
setInterval方法则是表示间隔一定时间反复执行某操作。
如果用setTimeout实现setInerval的功能,就需要在执行的程序中再定时调用自己才行。如果要清除计数器需要 根据使用的方法不同,调用不同的清除方法:
例如:(1):

t=setTimeout('northsnow()',1000);
clearTimeout(t);
(2):
t=setInterval('northsnow()',1000);
clearInteval(t);
setTimeout()

语法
var t=setTimeout("javascript语句",毫秒);

第一个参数是含有 JavaScript 语句的字符串。这个语句可能诸如 "alert('5 seconds!')",或者对函数的调用,诸如 alertMsg()"。
第二个参数指示从当前起多少毫秒后执行第一个参数。
提示:1000 毫秒等于一秒。

实例
当下面这个例子中的按钮被点击时,一个提示框会在5秒中后弹出。

<html>
  <head>
<script type="text/javascript">
function timedMsg() {
 var t=setTimeout("alert('5 seconds!')",5000);
 }
</script>
  </head>
  <body>
    <form>
      <input type="button" value="运行计时!" onClick="timedMsg()">
    </form>
  </body>
</html>
 

setInterval()
setInterval() 方法可按照指定的周期(以毫秒计)来调用函数或计算表达式。
setInterval() 方法会不停地调用函数,直到 clearInterval() 被调用或窗口被关闭。由 setInterval() 返回的 ID 值可用作 clearInterval() 方法的参数。
语法
setInterval(code,millisec[,"lang"])
实例
<html>
<head>
  <meta charset="utf-8"/>
  <title>setInterval实例 - 新锐工作室</title>
</head>
<body>
<script language="javascript">
  function endo(){
    alert("你好");
  }
  window.setInterval('endo()',5000);
</script>
</form>
<p> (c) Endige.net </p>
</body>
</html>

传参方法
无论是window.setTimeout还是window.setInterval,在使用函数名作为调用句柄时都不能带参数, 而在 许多场合必须要带参数,这就需要想方法解决。例如对于函数hello(_name),它用于针对用户名显示欢
迎信息:
var userName="jack";
//根据用户名显示欢迎信息
function hello(_name){
  alert("hello,"+_name);
}

这时,如果企图使用以下语句来使hello函数延迟3秒执行是不可行的:
window.setTimeout(hello(userName),3000);
这将使hello函数立即执行,并将返回值作为调用句柄传递给setTimeout函数,其结果并不是程序需要的。 而使用字符串形式可以达到想要的结果:
这里的字符串是一段JavaScript代码,其中的userName表示的是变量。 但这种写法不够直观,而且有些场合必须使用函数名,下面用一个小技巧来实现带参数函数的调用:
<script language="JavaScript" type="text/javascript">
<!--
var userName="jack";
//根据用户名显示欢迎信息
function hello(_name){
  alert("hello,"+_name);
}
//创建一个函数,用于返回一个无参数函数
function _hello(_name){
  return function(){
    hello(_name);
  }
}
window.setTimeout(_hello(userName),3000);
//-->
</script>

这里定义了一个函数_hello,用于接收一个参数,并返回一个不带参数的函数,
在这个函数内部使用了外部函数的参数,从而对其调用,不需要使用参数。在 window.setTimeout函数中,使用_hello(userName)来返回一个不带参数的
函数句柄,从而实现了参数传递的功能。
A.当要执行的方法中不需要参数时
<script type=”text/javascript”> 
//循环执行,每隔3秒钟执行一次showalert() 
window.setInterval(showalert, 3000);
function showalert() {
  alert(“你好”); 
}
//定时执行,5秒后执行show()
window.setTimeout(show,5000);
function show() {
  alert(“Hello”);
}
</script>

B.当要执行的方法中需要参数时
<script type=”text/javascript”> 
//循环执行,每隔3秒钟执行一次 showalert()
window.setInterval(function(){ 
  showalert(“你好!”); 
}, 3000); 
function showalert(mess) { 
  alert(mess); 
} 
//定时执行,5秒后执行showalert()
window.setTimeout(function(){ 
  showalert(“Hello”);
},5000); 
</script>
Javascript 相关文章推荐
神奇的代码 通杀各种网站-可随意修改复制页面内容
Jul 17 Javascript
通过length属性判断jquery对象是否存在
Oct 18 Javascript
JQuery的ready函数与JS的onload的区别详解
Nov 21 Javascript
jquery实现上下左右滑动的方法
Feb 09 Javascript
javascript函数命名的三种方式及区别介绍
Mar 22 Javascript
JavaScript笔记之数据属性和存储器属性
Mar 31 Javascript
AngularJS入门(用ng-repeat指令实现循环输出
May 05 Javascript
基于javascript实现的快速排序
Dec 02 Javascript
js自定义弹框插件的封装
Aug 24 Javascript
vue+axios+promise实际开发用法详解
Oct 15 Javascript
JavaScript Canvas编写炫彩的网页时钟
Oct 16 Javascript
详解vue beforeEach 死循环问题解决方法
Feb 25 Javascript
js简易namespace管理器 实例代码
Jun 21 #Javascript
JavaScript中的this关键字介绍与使用实例
Jun 21 #Javascript
js验证模型自我实现的具体方法
Jun 21 #Javascript
JS验证控制输入中英文字节长度(input、textarea等)具体实例
Jun 21 #Javascript
无缝滚动js代码通俗易懂(自写)
Jun 19 #Javascript
HTML5之lang属性与dir属性的详解
Jun 19 #Javascript
jQuery之ajax技术的详细介绍
Jun 19 #Javascript
You might like
8个必备的PHP功能开发
2015/10/02 PHP
[原创]php简单隔行变色功能实现代码
2016/07/09 PHP
postfixadmin忘记密码后的修改密码方法详解
2016/07/20 PHP
PHP超全局变量实现原理及代码解析
2020/09/01 PHP
不能再简单的无闪刷新验证码原理很简单
2007/11/05 Javascript
JS获取后台Cookies值的小例子
2013/03/04 Javascript
JavaScript中把数字转换为字符串的程序代码
2013/06/19 Javascript
JavaScript实现文本框中默认显示背景图片在获得焦点后消失的方法
2015/07/01 Javascript
jquery及js实现动态加载js文件的方法
2016/01/21 Javascript
javascript insertAfter()定义与用法示例
2016/07/25 Javascript
微信小程序 获取二维码实例详解
2017/06/23 Javascript
nuxt+axios解决前后端分离SSR的示例代码
2017/10/24 Javascript
详解vue 路由跳转四种方式 (带参数)
2019/04/28 Javascript
element-ui table行点击获取行索引(index)并利用索引更换行顺序
2020/02/27 Javascript
js canvas实现俄罗斯方块
2020/10/11 Javascript
原生js中运算符及流程控制示例详解
2021/01/05 Javascript
python中list列表的高级函数
2016/05/17 Python
Python 遍历列表里面序号和值的方法(三种)
2017/02/17 Python
Python中一些不为人知的基础技巧总结
2018/05/19 Python
python dataframe 输出结果整行显示的方法
2018/06/14 Python
python批量创建指定名称的文件夹
2019/03/21 Python
Python使用POP3和SMTP协议收发邮件的示例代码
2019/04/16 Python
python3中使用__slots__限定实例属性操作分析
2020/02/14 Python
python实现无边框进度条的实例代码
2020/12/30 Python
英国评分最高的女性剃须刀订阅盒:FFS Beauty
2018/01/25 全球购物
后勤人员岗位职责
2013/12/17 职场文书
中专自我鉴定
2014/02/05 职场文书
护士的自我鉴定
2014/02/07 职场文书
厨师长岗位职责
2014/03/02 职场文书
毕业横幅标语
2014/10/08 职场文书
房屋租赁合同解除协议书
2014/10/11 职场文书
高中班主任心得体会
2016/01/07 职场文书
民警忠诚教育心得体会
2016/01/23 职场文书
python numpy中setdiff1d的用法说明
2021/04/22 Python
Python中 range | np.arange | np.linspace三者的区别
2022/03/22 Python
MongoDB误操作后使用oplog恢复数据
2022/04/11 MongoDB