JavaScript setInterval()与setTimeout()计时器


Posted in Javascript onDecember 27, 2019

JavaScript是单线程语言,但是它可以通过设置超时值和间歇时间值来指定代码在特定的时刻执行。超时值是指在指定时间之后执行代码,间歇时间值是指每隔指定的时间就执行一次代码。

超时调用

超时调用使用window对象的setTimeout()方法,它接受两个参数:要执行的代码和以毫秒表示的时间(代码执行前的等待时间)。其中,第一个参数可以是一个字符串(和eval()中使用的字符串一样),也可以是一个函数。

JavaScript setInterval()与setTimeout()计时器

第二个参数是一个表示等待多长时间的毫秒数,但是在该时间过去后代码并不一定执行。JavaScript是一个单线程序的解释器,因此一定时间内只能执行一段代码。为了控制要执行的代码,就有一个JavaScript任务队列。这些任务会按照将它们添加到任务队列的顺序执行。setTimeout()的第二个参数告诉JavaScript再过多长时间把当前任务添加到队列中。如果队列是空的,那么添加的代码则会立即执行;如果队列不是空的,那么添加的代码会在前面的代码执行完毕后再执行。

调用setTimeout()之后,该方法会返回一个数值ID,表示超时调用。这个超时调用ID是计划执行代码的唯一标识符,可以通过它来取消超时调用。取消超时调用使用方法clearTimeout();

JavaScript setInterval()与setTimeout()计时器

间歇调用

间歇调用与超时调用类似,只不过它会按照指定的时间间隔重复执行代码,直至间歇调用被取消或页面被卸载。设置间歇调用的方法是setInterval(),它接收的参数与setTimeout()相同。取消间歇调用的重要性远高于超时调用。

JavaScript setInterval()与setTimeout()计时器

但是通常情况下,很少真正使用间歇调用,因为后一个间歇调用可能在前一个间歇调用结束之前调用。因此,我们通常会使用超时调用来模拟间歇调用

JavaScript setInterval()与setTimeout()计时器

下面看两个小demo:

1、获得当前日期并让它显示在文本框内,点击“stop”按钮后事件静止。(间歇调用) 

 HTML代码:

<input type="text" size="50" id="clock" />
<input type="button" value="Stop" id="btn" />

JavaScript代码:

function clock(){
  var time = new Date();
  document.getElementById("clock").value = time;  
  var btn =document.getElementById("btn");
  btn.onclick = function(){
    clearInterval(t); 
  }
}
var t = setInterval(clock,1000);

2、使用setTimeou()实现计数统计效果,并在文本框中显示数值。

HTML代码:

<input type="text" id="count" />

JavaScript代码:

var num = 0;
function startCount(){
  document.getElementById("count").value = num;
  num += 1;
  setTimeout(startCount,1000);  //setTimeout是超时调用,使用递归模拟间歇调用
}  
setTimeout(startCount,1000);  //1s后执行

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
javascript 面向对象全新理练之原型继承
Dec 03 Javascript
用js模拟JQuery的show与hide动画函数代码
Sep 20 Javascript
JS在IE下缺少标识符的错误
Jul 23 Javascript
DOM基础教程之使用DOM + Css
Jan 20 Javascript
bootstrap模态框消失问题的解决方法
Dec 02 Javascript
自适应布局meta标签中viewport、content、width、initial-scale、minimum-scale、maximum-scale总结
Aug 18 Javascript
详解小程序缓存插件(mrc)
Aug 17 Javascript
详解Next.js页面渲染的优化方案
Jan 27 Javascript
uni-app之APP和小程序微信授权方法
May 09 Javascript
javascript使用substring实现的展开与收缩文字功能示例
Jun 17 Javascript
JS实现在线ps功能详解
Jul 31 Javascript
Ant Design的可编辑Tree的实现操作
Oct 31 Javascript
vue中watch和computed为什么能监听到数据的改变以及不同之处
Dec 27 #Javascript
React中使用UMEditor的方法示例
Dec 27 #Javascript
node.js express捕获全局异常的三种方法实例分析
Dec 27 #Javascript
JavaScript中变量提升机制示例详解
Dec 27 #Javascript
vue 中 elment-ui table合并上下两行相同数据单元格
Dec 26 #Javascript
Vue使用虚拟dom进行渲染view的方法
Dec 26 #Javascript
node.js Promise对象的使用方法实例分析
Dec 26 #Javascript
You might like
图书管理程序(二)
2006/10/09 PHP
关于IIS php调用com组件的权限问题
2012/01/11 PHP
ThinkPHP页面跳转success与error方法概述
2014/06/25 PHP
PHP设计模式之适配器模式定义与用法详解
2018/04/03 PHP
HTML中不支持静态Expando的元素的问题
2007/03/08 Javascript
js调用后台servlet方法实例
2013/06/09 Javascript
js Select下拉列表框进行多选、移除、交换内容的具体实现方法
2013/08/13 Javascript
JavaScript 浏览器对象模型BOM使用介绍
2015/04/13 Javascript
JavaScript图片轮播代码分享
2015/07/31 Javascript
微信小程序 实现动态显示和隐藏某个控件
2017/04/27 Javascript
bootstrap轮播图示例代码分享
2017/05/17 Javascript
对于input 框限定输入值为浮点型的js代码
2017/09/25 Javascript
React Native 搭建开发环境的方法步骤
2017/10/30 Javascript
jQuery中ajax获取数据赋值给页面的实例
2017/12/31 jQuery
javascript/jquery实现点击触发事件的方法分析
2019/11/11 jQuery
详解Vue 数据更新了但页面没有更新的 7 种情况汇总及延伸总结
2020/05/28 Javascript
vue实现移动端触屏拖拽功能
2020/08/21 Javascript
[06:33]3.19 DOTA2发布会 海涛、冷冷、2009见证希望
2014/03/21 DOTA
[54:10]完美世界DOTA2联赛PWL S2 Magma vs FTD 第二场 11.29
2020/12/03 DOTA
详解Python中open()函数指定文件打开方式的用法
2016/06/04 Python
Python中的日期时间处理详解
2016/11/17 Python
浅谈python中的__init__、__new__和__call__方法
2017/07/18 Python
Python编程实现使用线性回归预测数据
2017/12/07 Python
Pycharm在创建py文件时,自动添加文件头注释的实例
2018/05/07 Python
pyqt 实现在Widgets中显示图片和文字的方法
2019/06/13 Python
html5 学习简单的拾色器
2010/09/03 HTML / CSS
html5使用window.postMessage进行跨域实现数据交互的一次实战
2021/02/24 HTML / CSS
园林技术个人的自我评价
2014/02/15 职场文书
大学生新学期计划书
2014/04/28 职场文书
政风行风评议个人心得体会
2014/10/29 职场文书
因个人原因离职的辞职信范文
2015/05/12 职场文书
用电申请报告范文
2015/05/18 职场文书
2016秋季运动会前导词
2015/11/25 职场文书
Python还能这么玩之用Python做个小游戏的外挂
2021/06/04 Python
详解JavaScript中Arguments对象用途
2021/08/30 Javascript
【海涛dota解说】海涛小满开黑4v5被破两路翻盘潮汐第一视角解说
2022/04/01 DOTA