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 相关文章推荐
javascript EXCEL 操作类代码
Jul 30 Javascript
jquery select选中的一个小问题
Oct 11 Javascript
JavaScript中各种编码解码函数的区别和注意事项
Aug 19 Javascript
JavaScript使ifram跨域相互访问及与PHP通信的实例
Mar 03 Javascript
AngularJS基础 ng-switch 指令简单示例
Aug 03 Javascript
详解AngularJs中$resource和restfu服务端数据交互
Sep 21 Javascript
关于vue-resource报错450的解决方案
Jul 24 Javascript
前端必备插件之纯原生JS的瀑布流插件Macy.js
Nov 22 Javascript
Node使用Sequlize连接Mysql报错:Access denied for user ‘xxx’@‘localhost’
Jan 03 Javascript
element-ui 的el-button组件中添加自定义颜色和图标的实现方法
Oct 26 Javascript
原生JS实现无缝轮播图片
Jun 24 Javascript
vue实现可移动的悬浮按钮
Mar 04 Vue.js
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
PHP安全配置
2006/12/06 PHP
PHP批量生成缩略图的代码
2008/07/19 PHP
Yii入门教程之Yii安装及hello world
2014/11/25 PHP
Laravel框架使用Redis的方法详解
2018/05/30 PHP
jQuery(非HTML5)可编辑表格实现代码
2012/12/11 Javascript
javascript实现json页面分页实例代码
2014/02/20 Javascript
jquery实现侧边弹出的垂直导航
2014/12/09 Javascript
javaScript的函数对象的声明详解
2015/02/06 Javascript
JavaScript中的toDateString()方法使用详解
2015/06/12 Javascript
web前端页面生成exe可执行文件的方法
2018/02/08 Javascript
Vue-router 切换组件页面时进入进出动画方法
2018/09/01 Javascript
微信小程序 调用远程接口 给全局数组赋值代码实例
2019/08/13 Javascript
JS数组方法slice()用法实例分析
2020/01/18 Javascript
JavaScript中作用域链的概念及用途讲解
2020/08/06 Javascript
js实现3D粒子酷炫动态旋转特效
2020/09/13 Javascript
[04:16]DOTA2英雄梦之声_第09期_斧王
2014/06/21 DOTA
python列表操作实例
2015/01/14 Python
Python实现自定义顺序、排列写入数据到Excel的方法
2018/04/23 Python
对Python发送带header的http请求方法详解
2019/01/02 Python
Django+Xadmin构建项目的方法步骤
2019/03/06 Python
pandas DataFrame的修改方法(值、列、索引)
2019/08/02 Python
Python Django 简单分页的实现代码解析
2019/08/21 Python
HTML5录音实践总结(Preact)
2020/05/07 HTML / CSS
美国最大的香水出口:FragranceX.com
2017/11/04 全球购物
面向对象编程OOP的优点
2013/01/22 面试题
大专毕业自我鉴定
2014/02/04 职场文书
小班秋游活动方案
2014/02/22 职场文书
道德大讲堂实施方案
2014/05/14 职场文书
企业活动策划方案
2014/06/02 职场文书
机关领导干部作风整顿整改措施
2014/09/19 职场文书
房屋租赁合同协议书范本
2014/10/19 职场文书
2014年领导班子工作总结
2014/12/11 职场文书
酒会邀请函
2015/01/31 职场文书
杨善洲电影观后感
2015/06/04 职场文书
少年雷锋观后感
2015/06/10 职场文书
医疗纠纷调解协议书
2015/08/06 职场文书