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异步表单提交,图片上传,兼容异步模拟ajax技术
May 10 Javascript
javascript中最常用的继承模式 组合继承
Aug 12 Javascript
Eclipse下jQuery文件报错出现错误提示红叉
Jan 13 Javascript
JavaScript将取代AppleScript?
Sep 18 Javascript
浅谈$(document)和$(window)的区别
Jul 15 Javascript
很棒的js Tab选项卡切换效果
Aug 30 Javascript
jquery.uploadifive插件怎么解决上传限制图片或文件大小问题
May 08 jQuery
详解vue2 $watch要注意的问题
Sep 08 Javascript
浅析Vue中method与computed的区别
Mar 06 Javascript
生产制造追溯系统之再说条码打印
Jun 03 Javascript
微信小程序添加插屏广告并设置显示频率(一天一次)
Dec 06 Javascript
Vue实现星级评价效果实例详解
Dec 30 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
PHP与javascript的两种交互方式
2006/10/09 PHP
php数组排序usort、uksort与sort函数用法
2014/11/17 PHP
Symfony2开发之控制器用法实例分析
2016/02/05 PHP
PHP编程实现微信企业向用户付款的方法示例
2017/07/26 PHP
PHP读取文件,解决中文乱码UTF-8的方法分析
2020/01/22 PHP
js 与或运算符 || &amp;&amp; 妙用
2009/12/09 Javascript
这段js代码得节约你多少时间
2011/12/20 Javascript
JavaScript中的style.display属性操作
2013/03/27 Javascript
js获取对象为null的解决方法
2013/11/21 Javascript
node.js中的fs.realpathSync方法使用说明
2014/12/16 Javascript
javascript实现链接单选效果的方法
2015/05/13 Javascript
JQuery实现图片轮播效果
2015/09/15 Javascript
jQuery实现的倒计时效果实例小结
2016/04/16 Javascript
使用jQuery.form.js/springmvc框架实现文件上传功能
2016/05/12 Javascript
JavaScript读二进制文件并用ajax传输二进制流的方法
2016/07/18 Javascript
js实现二级导航功能
2017/03/03 Javascript
JS检测数组类型的方法小结
2017/03/14 Javascript
原生JS实现ajax与ajax的跨域请求实例
2017/12/01 Javascript
微信小程序使用swiper组件实现层叠轮播图
2018/11/04 Javascript
vue.js实现三级菜单效果
2019/10/19 Javascript
原生小程序封装跑马灯效果
2020/10/21 Javascript
[43:58]DOTA2-DPC中国联赛定级赛 LBZS vs SAG BO3第一场 1月8日
2021/03/11 DOTA
python模块之sys模块和序列化模块(实例讲解)
2017/09/13 Python
基于循环神经网络(RNN)实现影评情感分类
2018/03/26 Python
python实现按长宽比缩放图片
2018/06/07 Python
Tensorflow 实现将图像与标签数据转化为tfRecord文件
2020/02/17 Python
基于python实现模拟数据结构模型
2020/06/12 Python
全球知名鞋履品牌授权零售商:Journeys
2016/09/17 全球购物
通信工程毕业生求职信
2013/11/16 职场文书
酒店门卫岗位职责
2013/12/29 职场文书
生物学学生自我评价
2014/01/17 职场文书
护士岗前培训自我评鉴
2014/02/28 职场文书
学习全国两会精神心得体会范文
2014/03/17 职场文书
大足石刻导游词
2015/02/02 职场文书
刑事撤诉申请书
2015/05/18 职场文书
培训计划通知
2015/07/15 职场文书