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 相关文章推荐
jquery在Chrome下获取图片的长宽问题解决
Mar 20 Javascript
js实现通用的微信分享组件示例
Mar 10 Javascript
基于豆瓣API+Angular开发的web App
Jan 02 Javascript
原生js实现类似弹窗抖动效果
Apr 02 Javascript
JS实现的5级联动Select下拉选择框实例
Aug 17 Javascript
JavaScript重定向URL参数的两种方法小结
Oct 19 Javascript
JavaScript基本语法_动力节点Java学院整理
Jun 26 Javascript
原生JS实现循环Nodelist Dom列表的4种方式示例
Feb 11 Javascript
Vue Cli3 创建项目的方法步骤
Oct 15 Javascript
使用electron实现百度网盘悬浮窗口功能的示例代码
Oct 24 Javascript
详解vue-cli3 中跨域解决方案
Apr 10 Javascript
Electron + vue 打包桌面操作流程详解
Jun 24 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
php $_SERVER当前完整url的写法
2009/11/12 PHP
php使用str_replace实现输入框回车替换br的方法
2014/11/24 PHP
为PHP5.4开启Zend OPCode缓存
2014/12/26 PHP
PHP两种实现无级递归分类的方法
2017/03/02 PHP
thinkPHP框架中执行事务的方法示例
2018/05/31 PHP
如何优雅的使用 laravel 的 validator验证方法
2018/11/11 PHP
ThinkPHP3.2.3框架实现执行原生SQL语句的方法示例
2019/04/03 PHP
理解Javascript_03_javascript全局观
2010/10/11 Javascript
JavaScript三元运算符的多种使用技巧
2015/04/16 Javascript
直接拿来用的15个jQuery代码片段
2015/09/23 Javascript
javascript中数组和字符串的方法对比
2016/07/20 Javascript
聊一聊JS中的prototype
2016/09/29 Javascript
bootstrap下拉列表与输入框组结合的样式调整
2016/10/08 Javascript
基于JavaScript实现的插入排序算法分析
2017/04/14 Javascript
详解Node.js串行化流程控制
2017/05/04 Javascript
微信小程序使用Socket的实例
2017/09/19 Javascript
Python记录详细调用堆栈日志的方法
2015/05/05 Python
python统计文本文件内单词数量的方法
2015/05/30 Python
Python中__init__.py文件的作用详解
2016/09/18 Python
Tensorflow加载预训练模型和保存模型的实例
2018/07/27 Python
python实现图书借阅系统
2019/02/20 Python
关于Python 常用获取元素 Driver 总结
2019/11/24 Python
Python Selenium实现无可视化界面过程解析
2020/08/25 Python
Html5实现如何在两个div元素之间拖放图像
2013/03/29 HTML / CSS
Wiggle中国:英国骑行、跑步、游泳 & 铁三运动装备专卖网店
2016/08/02 全球购物
会计专业自我鉴定范文
2013/12/29 职场文书
生日宴会答谢词
2014/01/09 职场文书
资源工程专业毕业生求职信
2014/02/27 职场文书
中学生学雷锋演讲稿
2014/04/26 职场文书
优秀学生党员先进事迹材料
2014/05/29 职场文书
党员示范岗材料
2014/12/19 职场文书
《迟到》教学反思
2016/02/24 职场文书
甜美蛋糕店的创业计划书模板,拿来即用!
2019/08/21 职场文书
使用PostGIS完成两点间的河流轨迹及流经长度的计算(推荐)
2022/01/18 PostgreSQL
tomcat的catalina.out日志按自定义时间格式进行分割的操作方法
2022/04/02 Servers
MySQL的存储过程和相关函数
2022/04/26 MySQL