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 相关文章推荐
模拟用户操作Input元素,不会触发相应事件
May 11 Javascript
深入探讨JavaScript String对象
Mar 09 Javascript
js实现类似jquery里animate动画效果的方法
Apr 10 Javascript
AngularJS基础 ng-model 指令详解及示例代码
Aug 02 Javascript
vue.js 上传图片实例代码
Jun 22 Javascript
详解如何使用webpack+es6开发angular1.x
Aug 16 Javascript
Node.js Event Loop各阶段讲解
Mar 08 Javascript
JavaScript中常用的简洁高级技巧总结
Mar 10 Javascript
详解Vue3.0 前的 TypeScript 最佳入门实践
Jun 18 Javascript
vue 实现模糊检索并根据其他字符的首字母顺序排列
Sep 19 Javascript
node读写Excel操作实例分析
Nov 06 Javascript
Vue-cli assets SubDirectory及PublicPath区别详解
Aug 18 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 imagecreatefrombmp 从BMP文件或URL新建一图像
2012/07/16 PHP
PHP防止跨域提交表单
2013/11/01 PHP
php检测用户是否用手机(Mobile)访问网站的类
2014/01/09 PHP
如何取得中文输入的真实长度?
2006/06/24 Javascript
初学prototype,发个JS接受URL参数的代码
2006/09/25 Javascript
javascript 动态table添加colspan\rowspan 参数的方法
2009/07/25 Javascript
JAVASCRIPT车架号识别/验证函数代码 汽车车架号验证程序
2012/01/08 Javascript
JavaScript中的匀速运动和变速(缓冲)运动详细介绍
2012/11/11 Javascript
点击弹出层外区域关闭弹出层jquery特效示例
2013/08/25 Javascript
JavaScript中的prototype.bind()方法介绍
2014/04/04 Javascript
Javascript页面跳转常见实现方式汇总
2015/11/28 Javascript
javascript实现一个简单的弹出窗
2016/02/22 Javascript
详解Vue用axios发送post请求自动set cookie
2017/05/10 Javascript
bootstrap动态添加面包屑(breadcrumb)及其响应事件的方法
2017/05/25 Javascript
vue使用drag与drop实现拖拽的示例代码
2017/09/07 Javascript
利用node.js如何创建子进程详解
2017/12/09 Javascript
基于axios 的responseType类型的设置方法
2019/10/29 Javascript
vuex存取值和映射函数使用说明
2020/07/24 Javascript
python实现的生成随机迷宫算法核心代码分享(含游戏完整代码)
2014/07/11 Python
在Python中操作文件之read()方法的使用教程
2015/05/24 Python
Python列表list内建函数用法实例分析【insert、remove、index、pop等】
2017/07/24 Python
python实现文件助手中查看微信撤回消息
2019/04/29 Python
python实现五子棋游戏
2019/06/18 Python
windows、linux下打包Python3程序详细方法
2020/03/17 Python
linux 下selenium chrome使用详解
2020/04/02 Python
python中for in的用法详解
2020/04/17 Python
Myprotein荷兰官网:欧洲第一运动营养品牌
2020/07/11 全球购物
电大自我鉴定范文
2013/10/01 职场文书
园艺师求职信
2014/03/10 职场文书
2014年小学教学工作总结
2014/11/13 职场文书
公司承诺函范文
2015/01/21 职场文书
企业承诺书格式范文
2015/04/28 职场文书
2015年语文教师工作总结
2015/05/25 职场文书
Python控制台输出俄罗斯方块的方法实例
2021/04/17 Python
Html5通过数据流方式播放视频的实现
2021/04/27 HTML / CSS
python实现进度条的多种实现
2021/04/29 Python