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中Array 对象相关的几个方法
Dec 22 Javascript
简单谈谈json跨域
Mar 13 Javascript
深入理解jQuery事件绑定
Jun 02 Javascript
jquery轮播的实现方式 附完整实例
Jul 28 Javascript
AngularJS 路由详解和简单实例
Jul 28 Javascript
js+css3实现旋转效果
Jan 20 Javascript
angular.js + require.js构建模块化单页面应用的方法步骤
Jul 19 Javascript
基于vue+canvas的excel-like组件实例详解
Nov 28 Javascript
详解JQuery基础动画操作
Apr 12 jQuery
微信小程序聊天功能的示例代码
Jan 13 Javascript
JS实现悬浮球只在一侧滑动并且是横屏状态下
Aug 19 Javascript
Vue实现图书管理案例
Jan 20 Vue.js
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
《魔兽争霸3:重制版》翻车了?你想要的我们都没有
2019/11/07 魔兽争霸
PHP 上传文件大小限制
2009/07/05 PHP
深入解析fsockopen与pfsockopen的区别
2013/07/05 PHP
php实现的CSS更新类实例
2014/09/22 PHP
php头像上传预览实例代码
2017/05/02 PHP
PHP7创建销毁session的实例方法
2020/02/03 PHP
Jquery+ajax请求data显示在GridView上(asp.net)
2010/08/27 Javascript
jquery刷新页面的实现代码(局部及全页面刷新)
2011/07/11 Javascript
js性能优化 如何更快速加载你的JavaScript页面
2012/03/17 Javascript
jQuery页面图片伴随滚动条逐渐显示的小例子
2013/03/21 Javascript
Javascript和HTML5利用canvas构建Web五子棋游戏实现算法
2013/07/17 Javascript
js函数获取html中className所在的内容并去除标签
2013/09/08 Javascript
Jquery的Tabs内容轮换效果实现代码,几行搞定
2014/02/12 Javascript
详解jQuery选择器
2016/12/21 Javascript
神级程序员JavaScript300行代码搞定汉字转拼音
2017/05/20 Javascript
基于angular实现模拟微信小程序swiper组件
2017/06/11 Javascript
jQuery实现的简单图片轮播效果完整示例
2018/02/08 jQuery
vue2.0使用swiper组件实现轮播的示例代码
2018/03/03 Javascript
vue2.0安装style/css loader的方法
2018/03/14 Javascript
去掉vue 中的代码规范检测两种方法(Eslint验证)
2018/03/21 Javascript
vue-router history模式下的微信分享小结
2018/07/05 Javascript
Nodejs文件上传、监听上传进度的代码
2020/03/27 NodeJs
[01:08:09]DOTA2上海特级锦标赛主赛事日 - 1 胜者组第一轮#1Liquid VS Alliance第二局
2016/03/02 DOTA
解决pandas中读取中文名称的csv文件报错的问题
2018/07/04 Python
flask框架中勾子函数的使用详解
2018/08/01 Python
PythonWeb项目Django部署在Ubuntu18.04腾讯云主机上
2019/04/01 Python
python实现的读取网页并分词功能示例
2019/10/29 Python
Python列表去重复项的N种方法(实例代码)
2020/05/12 Python
Pandas把dataframe或series转换成list的方法
2020/06/14 Python
Python读取二进制文件代码方法解析
2020/06/22 Python
Python使用lambda抛出异常实现方法解析
2020/08/20 Python
严选全球尖货,立足香港:Bonpont宝盆
2018/07/24 全球购物
普通PHP程序员笔试题
2016/01/01 面试题
物流专业大学生求职信范文
2013/10/28 职场文书
护士演讲稿范文
2014/01/05 职场文书
学校领导班子对照检查材料
2014/09/24 职场文书