详解javascript高级定时器


Posted in Javascript onDecember 31, 2015

setTimeout()和setInterval()可以用来创建定时器,其基本的用法这里就不再做介绍了。这里主要介绍一下javascript的代码队列。在javascript中没有任何代码是立即执行的,一旦进程空闲则尽快执行。所以说定时器中设置的时间并不代表执行时间就一定相符,而是代表代码会在指定时间间隔后加入到队列中进行等待。如果在这个时间点上,队列中没有其他东西,那么这段代码就会被执行,表面上看上去好像代码就在精确指定的时间点上执行了。所以就会产生一些问题。

重复定时器

通常,我们使用setInterval方法来以相同时间间隔重复执行某段代码。但是使用该方法会有两个问题:第一个就是某些间隔会被跳过;第二个就是多个定时器的代码执行之间的间隔可能会比预期的小。
在这里,我们来举个例子:如果某个onclick事件处理程序使用setInterval设置了一个200ms间隔的重复定时器,如果事件处理程序花了300ms的时间完成,就会跳过一个时间间隔同时运行着一个定时器代码。
我们也可以通过下面的代码来得到结论:

//重复定时器
var i =0;
setInterval(function(){
 //如果事件处理时间长于间隔时间
 i++;
 for(var j=0;j<100000000;j++){}
 document.write(i+' ');
},100);
//可以明显感觉到时间间隔不相等
为了避免这种时间间隔的问题,我们可以采用链式调用setTimeout方法来取代setInterval。

//可以采用链式调用setTimeout来取代setInterval
var i = 0;
setTimeout(function(){
 //处理内容
 i++;
 for(var j=0;j<100000000;j++){}
 document.write(i+' ');
 //
 setTimeout(arguments.callee,100);
},100);
//这样处理效果明显好多了。

每次函数执行的时候都会创建一个新的定时器,第二个setTimeout调用使用了arguments.callee来获取对当前执行的函数的引用,并为其设置另外一个定时器。这样做是为了在前一个定时器代码执行完之前,不会向队列插入新的定时器代码,确保不会有任何缺失的间隔,也保证了在下一次定时器代码执行之前,至少要等待指定的间隔,避免了连续的运行。可谓一举两得,现在主流框架中的动画一般都是这样来实现重复定时的。

函数节流

定时器不仅仅是用来定时的,也可以用来缓解浏览器的压力。浏览器中某些计算和处理要比其他的昂贵很多,比如说DOM操作,就会需要更多的内存和CPU时间,连续使用过多的DOM操作可能会导致浏览器挂起,甚至崩溃。
函数节流的基本思想就是,某些代码不可以在没有间断的情况连续重复执行。第一次调用函数,创建一个定时器,在指定的时间间隔之后运行代码。当第二次调用该函数时,它会清除前一次的定时器并设置一个。目的就是为了在执行函数的请求停止一段时间后再执行。
代码如下:

//再来谈谈函数节流
function throttle(method,context){
 clearTimeout(method.tId);
 method.tId = setTimeout(function(){
  method.call(context);
 },100);
}
//该函数接受两个参数,第一个是要执行的函数,第二个是作用域。
//使用方法demo
//未使用情况:
window.onresize = function(){
 var div = document.getElementByTagName(body);
 div.style.height = div.offsetWidth +'px';
}
//使用情况;
function resizeDiv(){
 var div = document.getElementByTagName(body);
 div.style.height = div.offsetWidth +'px';
}
window.onresize = function(){
 throttle(resizeDiv);
};
//只要代码是周期性执行的,都应该使用节流。

这样给用户的感觉并不会很大,确是给浏览器减少了不少的压力,函数节流也是很多框架常用的技巧之一。

以上就是关于javascript高级定时器的相关介绍,希望对大家的学习有所帮助。

Javascript 相关文章推荐
js判断一个元素是否为另一个元素的子元素的代码
Mar 21 Javascript
jquery 插件开发 extjs中的extend用法小结
Jan 04 Javascript
JQuery select(下拉框)操作方法汇总
Apr 15 Javascript
如何用javascript计算文本框还能输入多少个字符
Jul 29 Javascript
jQuery+css实现的切换图片功能代码
Jan 27 Javascript
全屏js头像上传插件源码高清版
Mar 29 Javascript
详解Jquery实现ready和bind事件
Apr 14 Javascript
jQuery实现radio第一次点击选中第二次点击取消功能
May 15 jQuery
基于vue-video-player自定义播放器的方法
Mar 21 Javascript
VUE DOM加载后执行自定义事件的方法
Sep 07 Javascript
微信上传视频文件提示(推荐)
Nov 22 Javascript
VsCode与Node.js知识点详解
Sep 05 Javascript
jQuery动画效果相关方法实例分析
Dec 31 #Javascript
js实现文字垂直滚动和鼠标悬停效果
Dec 31 #Javascript
jquery正则表达式验证(手机号、身份证号、中文名称)
Dec 31 #Javascript
jQuery语法小结(超实用)
Dec 31 #Javascript
解决JS无法调用Controller问题的方法
Dec 31 #Javascript
简单谈谈JavaScript的同步与异步
Dec 31 #Javascript
jQuery实现简单的图片查看器
Sep 11 #Javascript
You might like
PHP5.5迭代生成器用法实例详解
2016/03/16 PHP
PHP实现链式操作的三种方法详解
2017/11/16 PHP
Ajax请求PHP后台接口返回信息的实例代码
2018/08/21 PHP
PHP count()函数讲解
2019/02/03 PHP
PHP常见的序列化与反序列化操作实例分析
2019/10/28 PHP
PHP实现图片防盗链破解操作示例【解决图片防盗链问题/反向代理】
2020/05/29 PHP
IE浏览器PNG图片透明效果代码
2008/09/02 Javascript
js鼠标滑过图片震动特效的方法
2015/02/17 Javascript
js实现的tab标签切换效果代码分享
2015/08/25 Javascript
jQuery复制表单元素附源码分享效果演示
2015/09/30 Javascript
javascript性能优化之DOM交互操作实例分析
2015/12/12 Javascript
使用Web Uploader实现多文件上传
2016/06/08 Javascript
深入理解Javascript中的作用域链和闭包
2017/04/25 Javascript
jQuery实现判断上传图片类型和大小的方法示例
2018/04/11 jQuery
ES6的解构赋值实例详解
2019/05/06 Javascript
详解js根据百度地图提供经纬度计算两点距离
2019/05/13 Javascript
Javascript实现鼠标移入方向感知
2020/06/24 Javascript
解决qrcode.js生成二维码时必须定义一个空div的问题
2020/07/09 Javascript
Element Popover 弹出框的使用示例
2020/07/26 Javascript
python中Genarator函数用法分析
2015/04/08 Python
详解Python中的条件判断语句
2015/05/14 Python
Python的Django框架中if标签的相关使用
2015/07/15 Python
动感网页相册 python编写简单文件夹内图片浏览工具
2016/08/17 Python
flask应用部署到服务器的方法
2019/07/12 Python
TensorFLow 变量命名空间实例
2020/02/11 Python
python中68个内置函数的总结与介绍
2020/02/24 Python
python GUI库图形界面开发之PyQt5窗口背景与不规则窗口实例
2020/02/25 Python
Python绘制全球疫情变化地图的实例代码
2020/04/20 Python
简单介绍CSS3中Media Query的使用
2015/07/07 HTML / CSS
争论的故事教学反思
2014/02/06 职场文书
2014年迎新年联欢会活动策划方案
2014/02/26 职场文书
银行办公室岗位职责
2014/03/10 职场文书
公司年会抽奖活动主持词
2014/03/31 职场文书
2015年社会治安综合治理工作总结
2015/04/10 职场文书
numpy数据类型dtype转换实现
2021/04/24 Python
学会用Python实现滑雪小游戏,再也不用去北海道啦
2021/05/20 Python