setTimeout与setInterval简述:
setTimeout与setInterval使用方法基本相同,他们接受两个参数,第一个参数是需要执行的函数,第二个参数是执行的延迟时间,看栗子:
setTimeout(function(){
alert("hello"); //第一个参数为函数 你可以传入函数名 或一个匿名函数
},3000); //第二个参数为延迟时间 标识多少毫秒之后执行前一个函数
setInterval(function(){
alert("hello");
},3000);
setTimeout与setInterval唯一不同的是,setTimeout在指定的延迟时间到达后 向ui队列添加一个任务,函数会立即执行,setInterval则是在指定的延迟时间不断的向ui队列添加执行任务,如果你没有手动清除那么setInterval就会一直执行下去,直到页面被关闭,如果ui队列中存在由同一个setInterval创建的任务,那么后续任务将不会被添加到ui队列中。
通俗的说就是,让一个函数在指定时间之后再执行,和让一个函数在指定时间一直执行;
然而它在实际项目中有什么作用呢,我们可以利用setInterval制作定时幻灯片、实时数据更新、新闻列表滚动、jQuery的.animate()方法就是依靠定时器模拟动画效果。
提到定时器,就不得不先介绍一个JavaScript运行机制--》浏览器UI线程
用于执行javascript和更新用户界面的进程通常被称为“浏览器UI线程”
在浏览器中,Javascript执行与UI更新是发生在同一个进程(浏览器UI线程)中的。UI线程的工作基于一个简单的队列系统,任务会被保存到队列 中直到进程空闲时被提取出来执行。所以Javascript的执行会阻塞UI更新;反之,UI更新也会阻塞Javascript的执行。给用户的表现就是 浏览器在工作时短暂或长时间失去反应,用户的操作不能及时得到响应。而UI线程的阻塞很多时候是由于我们要在代码里进行长时间的脚本运算,超过了浏览器限 制,导致浏览器失去响应,冻结用户界面。传送门: Javascript之UI线程与性能优化
使用定时器可以异步处理需要大量运算的任务,它可以适时的避免ui更新与javascript执行之间的冲突
例如在某种极端环境下:
for(var i=0;i<5000;i++){
document.body.innerHTML += "hello"+i;
}
这段代码向body插入字符串 持续运行了五千次,在谷歌浏览器中这段代码会执行3秒左右 而这段时间页面始终是空白且不可操作的,这是一个非常常见的性能问题,在处理大量运算的时候,我们可以利用延迟执行将代码分成几段分别运行,可以有效改善代码执行速度,并且因为它是异步的 在执行中的空隙,ui会启动更新,因此并不会导致页面空白,用户体验提高;
setTimeout(function(){
for(var i=0;i<2500;i++){
document.body.innerHTML += "hello"+i;
}
//分段处理 五千次分成两段
setTimeout(function(){
for(var i=0;i<2500;i++){
document.body.innerHTML += "hello"+i;
}
},100);
},100);
假如向服务器请求一个超长的新闻列表,由于数据量过去庞大,单个循环解析数据持续时间过长,那么可以使用定时器分解任务,异步处理数据
一般情况下,我们处理数据都是这样的:
for(var i=0,len=msg.length;i<len;i++){
process(msg[i])
}
一般我们使用for或者while循环解析数据, 这样的问题是 在执行完成之前我们是没有办法控制页面的,数据越庞大越明显
使用定时器分解任务
使用定时器分解任务有两个前提
1.数据的处理不需要按照特定的顺序
2.是否必须同步处理,如果必须同步处理那么定时器不适用;
其核心理论是,每间隔一段时间(通常是30毫秒,视情况而定)执行当前项的处理函数;
封装之后的代码:
volist:function(name,id,callback,time){
//settimeout 异步循环 name为需要循环的array对象 id为要执行的解析函数 time设置每次运行的时间
if(time==undefined){time=30;};
var fattr = name.concat();//克隆数组
setTimeout(function(){
if(fattr.length>0){
id(fattr.shift()); //执行每一个数组项运行的函数
setTimeout(arguments.callee,time);
}else{
callback();//执行结束 回调函数
}
},time);//异步调用时间 默认30
}
还有另一种使用方式,将函数放在数组里,异步循环调用,将要执行的多个任务拆分成不同的子任务,分阶段分别执行:
function fun1(){
alert(1)
}
function fun2(){
alert(2)
}
function fun3(){
alert(3)
}
var farr = [fun1,fun2,fun3]; //将任务存储到数组中
setTimeout(function(){
if(farr.length>0){
var func=farr.shift(); //取出
func(); //执行函数
setTimeout(arguments.callee,300);
}else{
alert("执行完成")
}
},300); //300秒执行一次
定时器的性能问题
需要注意的是,当一个页面中存在多个定时器,他们执行的任务过多,往往会导致不可预料的问题;解决方法就是尽量避免创建多个定时器,只创建一个独立的定时器,让它分别执行不同的任务,另外每次调用setInterval()之前应清除前面已经无用的setInterval,或者是防止重复指定setInterval
var timer
//先清除
clearInterval(timer);
//再调用
timer = setInterval(function(){
......
},5000);
总结
合理使用定时器无疑能够增加页面的整体性能,在处理不需要同步,不需要顺序执行的任务时,可以考虑使用setTimeout代替for循环 异步处理任务。
分享到:
相关推荐
在JavaScript中,setTimeout和setInterval是两个基本的定时器函数,用于实现延迟执行或循环执行某个函数。然而,这两个函数在执行时往往和我们设置的延迟时间有出入。本文将深入探讨JS定时器的执行机制,分析why ...
Javascript的setTimeOut和setInterval函数应用非常广泛,它们都用来处理延时和定时任务,比如打开网页一段时间后弹出一个登录框,页面每隔一段时间发送异步请求获取最新数据等等。但它们的应用是有区别的。 ...
另一个区别是,由于`setTimeout`的异步性质,它可以在函数执行完毕后再执行,而`setInterval`则会在设定的间隔时间结束后立即尝试执行,即使前一次的执行还未完成。 在实际开发中,`setTimeout`常用于实现动画效果...
在JavaScript中,setTimeout和setInterval是两种常见的定时器函数,用于实现异步操作。JavaScript作为单线程语言,其主线程的执行是顺序的,但是在处理某些操作,如延时任务或者周期任务时,会借助事件循环机制和回...
在JavaScript中,`setTimeout`和`setInterval`是两个非常重要的定时器函数,它们用于在指定的时间后执行特定的函数。然而,`setInterval`在某些情况下可能不如我们期望的那样工作,因为它会周期性地不间断执行,即使...
在JavaScript编程中,`setTimeout()`和`setInterval()`是两个非常关键的函数,它们用于实现异步编程,特别是在处理动画、定时任务或者延迟执行代码时不可或缺。这两个函数都是全局对象`window`的方法,它们的区别...
1. **异步执行**:`setInterval`内部的代码可能会被其他同步任务阻塞,导致实际执行间隔变长。为避免这种情况,可以使用`setTimeout`递归调用来实现更准确的定时。 2. **清除定时器**:确保在不再需要执行定时任务...
前端开发中,我们会会经常使用定时器setinterval setTimeout等,但当我们离开页面时,定时器会被阻塞,导致我们再回到页面的时候定时任务会混乱运行,为些我的解决方案写了个简单demo,希望对你有所帮助
它们都用来处理延时和定时任务,比如打开网页一段时间后弹出一个登录框,页面每隔一段时间发送异步请求获取最新数据等,本文文章通过代码示例给大家介绍javascript中SetInterval与setTimeout的定时器用法
为了解决这个问题,我们可以自定义一个`setTimeout`方法,将所有定时器存储在一个数组中,然后在路由切换时统一清理。例如: ```javascript let _pageTimer = []; Vue.prototype.setTimeout = (fn, time) => { ...
在BOM系列的第一篇中,我们重点关注的是定时器`setTimeout`和`setInterval`,这两个方法是JavaScript中处理异步编程的重要工具。 `setTimeout`方法允许我们在指定的毫秒数之后执行一个函数或字符串。它接受两个主要...
需要注意的是,`setInterval`可能会因为浏览器的事件循环或其他异步操作而产生执行时间上的偏差,而`setTimeout`在某些情况下可能更可靠。此外,务必记得在不再需要定时器时清除它们,以避免资源浪费。
然而,为了实现异步操作,比如定时器的执行,JavaScript利用了回调队列以及事件循环机制。这一点,与传统的多线程编程模型(例如在服务器端的Node.js中)有所不同,后者允许同时运行多个线程。 在JavaScript中,...
在C++中,这样的功能通常需要开发者手动管理线程、定时器和事件循环,而`timercpp`库就是为了简化这个过程。 `timercpp`库的核心原理是基于异步编程模型,它可能采用了多线程、信号量、定时器或者事件驱动(如epoll...
在JavaScript的世界里,定时器主要由`setTimeout`和`setInterval`两个函数提供。本篇文章将深入探讨JavaScript定时器的工作原理以及它们在单线程环境中的行为。 ### 一、JavaScript的单线程模型 JavaScript是一种...
本文将深入探讨两种主要类型的JavaScript定时器:一次性执行的定时器(setTimeout)和重复执行的定时器(setInterval),以及如何清除这些定时器。 1. **一次性执行的定时器(setTimeout)** - `setTimeout` 函数...
此外,值得注意的是,`setTimeout`和`setInterval`在处理异步执行和事件循环时的行为也有所不同。在某些情况下,如当主线程被阻塞时,`setTimeout`的延迟可能会比预期更长,而`setInterval`可能会累积未执行的调用。...