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);
};
//只要代码是周期性运行的,都应该使用节流。

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

demo位置

深入理解javascript之高级定时器的更多相关文章

  1. 深入理解JavaScript定时机制和定时器注意问题

    容易欺骗别人感情的JavaScript定时器 JavaScript的setTimeout与setInterval是两个很容易欺骗别人感情的方法,因为我们开始常常以为调用了就会按既定的方式执行, 我想不 ...

  2. STM32 TIM1高级定时器RCR重复计数器的理解

    STM32 TIM1高级定时器RCR重复计数器的理解 TIMx_RCR重复计数器寄存器,重复计数器只支持高级定时器TIM1和TIM8,下面看标准外设库的TIM结构体的封装: typedef struc ...

  3. 深入理解JavaScript运行机制

    深入理解JavaScript运行机制 前言 本文是写作在给团队新人培训之际,所以其实本文的受众是对JavaScript的运行机制不了解或了解起来有困难的小伙伴.也就是说,其实真正的原理和本文阐述的并不 ...

  4. 深入理解javascript原型和闭包系列

    从下面目录中可以看到,本系列有16篇文章,外加两篇后补的,一共18篇文章.写了半个月,从9月17号开始写的.每篇文章更新时,读者的反馈还是可以的,虽然不至于上头条,但是也算是中规中矩,有看的人,也有评 ...

  5. 深入理解JavaScript的闭包特性如何给循环中的对象添加事件

    初学者经常碰到的,即获取HTML元素集合,循环给元素添加事件.在事件响应函数中(event handler)获取对应的索引.但每次获取的都是最后一次循环的索引.原因是初学者并未理解JavaScript ...

  6. 深入理解javascript原型和闭包(1)——一切都是对象

    “一切都是对象”这句话的重点在于如何去理解“对象”这个概念. ——当然,也不是所有的都是对象,值类型就不是对象. 首先咱们还是先看看javascript中一个常用的函数——typeof().typeo ...

  7. 深入理解javascript原型和闭包(2)——函数和对象的关系

    上文(理解javascript原型和作用域系列(1)——一切都是对象)已经提到,函数就是对象的一种,因为通过instanceof函数可以判断. var fn = function () { }; co ...

  8. 深入理解javascript原型和闭包(3)——prototype原型

    既typeof之后的另一位老朋友! prototype也是我们的老朋友,即使不了解的人,也应该都听过它的大名.如果它还是您的新朋友,我估计您也是javascript的新朋友. 在咱们的第一节(深入理解 ...

  9. 深入理解javascript原型和闭包(4)——隐式原型

    注意:本文不是javascript基础教程,如果你没有接触过原型的基本知识,应该先去了解一下,推荐看<javascript高级程序设计(第三版)>第6章:面向对象的程序设计. 上节已经提到 ...

随机推荐

  1. zjnu(1181)——石子合并

    这道题算是最简单的区间dp了..非常久之前写的,搞懂原理了就1A. 传送门:problem_id=1181">http://acm.zjnu.edu.cn/CLanguage/show ...

  2. iOS数据持久化 -- Core Data

    Core Data是一个功能强大的层,位于SQLite数据库之上,它避免了SQL的复杂性,能让我们以更自然的方式与数据库进行交互.Core Data将数据库行转换为OC对象(托管对象)来实现,这样无需 ...

  3. LeetCode SQL

    SQL查询练习一(From LeetCode) 1 select name,population,area 2 from World 3 where area > 3000000 or popu ...

  4. 35.自己实现vector模板库myvector

    myvector.h #pragma once //自己写的vector模板库 template <class T> class myvector { public: //构造 myvec ...

  5. leetcode 新题型----SQL,shell,system design

    leetcode 主要是一个针对北美的coder人群找工作的代码练习网站,我在2015年初次接触这个网站的时候,总共只有200多道题目,是一个类似acm 的a题网站.这些年变化越来越大,主要是因为找工 ...

  6. 线程1—Runnable

    随便选择两个城市作为预选旅游目标.实现两个独立的线程分别显示10次城市名,每次显示后休眠一段随机时间(1000ms以内),哪个先显示完毕,就决定去哪个城市.分别用Runnable接口和Thread类实 ...

  7. Python3基础笔记--基础知识

    目录: 一.变量问题 二.运算符总结 三.字符串问题 四.数据结构 五.文件操作 一.变量问题 变量存储在内存中的值.这就意味着在创建变量时会在内存中开辟一个空间.它自始至终都是在内存中活动,只有指明 ...

  8. Linux 下安装 redis 详情

    一:将redis 压缩包上传到 Linux  usr/local下 (一):在local 下创建一个 redis 目录 (二):上传redis压缩包到此目录下. 二:Linux 进入 local目录下 ...

  9. django orm 时间处理

    说明  datetime 类型赋值: 数据库设置时区为:utc 系统设置时区为:'Asia/Shanghai' 1.赋值为:‘2019-04-24 15:00:00’      数据库的结果为   ‘ ...

  10. PKU 2288 Islands and Bridges 状态dp

    题意: 给你一张地图,上面有一些岛和桥.你要求出最大的三角哈密顿路径,以及他们的数量. 哈密顿路:一条经过所有岛的路径,每个岛只经过一次. 最大三角哈密顿路:满足价值最大的哈密顿路. 价值计算分为以下 ...