目录
I. 总述
II. setTimeout()函数
III. setInterval()函数
IV. 新年倒计时案例
Javascript的setTimeOut和setInterval函数应用非常广泛,它们都用来处理延时和定时任务,下面这篇文章主要给大家介绍了关于JavaScript setTimeout和setInterval的用法与区别,如果大家有需要可以参考下。
首先,setTimeout()和setInterval()函数是JavaScript中两个很重要的关于"时间的函数",因此,我们在学习JavaScript的过程中,一定要对这两个函数有一个深入的学习,它们两个函数也是经常被使用的!
其中,如果分别用一句话来概括这两个函数,那么应该是这样的:
setTimeout(): 该函数能够按照设定的时间值延迟执行其中的事件。
setInterval(): 该函数能够按照设定的时间值作为间隔,周期性的执行其中的时间。
当然了,只是简述,细节方面,我们在下面的部分给大家做讲解。
首先是我们的setTimeout()函数,它的格式是怎么样的呢:
setTimeout(function,times, param1, param2, …);
setTimeout 是一个定时器函数,它允许我们在指定的时间后执行一次函数。其中,function 是我们要执行的函数,times 是延迟的时间(以毫秒为单位),param1, param2, … 等是传递给函数的参数(可选)。例如我们看这段简单的代码:
setTimeout(function(){
alert("hello,setTimeout()");
}, 1000);
运行之后,它会在1s的延迟之后,弹出一个弹框,其中,1000的单位是毫秒!
学到这里,大家觉得很简单,对吗?好的,那我给一段代码,大家猜一下它会输出什么:
for (var i = 1; i <= 5; i++) {
setTimeout(function () {
alert(i)
}, 1000)
}
哎,有人要说了,简单啊,这不是输出:1 2 3 4 5 吗?
然而实际上,它输出了6 6 6 6 6,所以这是为什么呢?因为setTimeout()是一个异步执行函数,说人话就是,它里面的函数体,并不会在每一次执行的时候立刻运行,而是会丢进执行队列中,等待"主线任务"全部完成,才会执行它。
于是在5次for循环后,i的值是5,传进去,弹出了6个6。
那么有没有解法呢?我给大家两种解法:
1️⃣ 使用关键字let:
for (let i = 1; i <= 5; i++) {
setTimeout(function () {
alert(i);
}, 1000)
}
执行结果:
那为啥使用let就可以了呢:
其实使用let之后,也没有改变执行机制,仍然是最后执行的alert(),但是let可以在每一次把更新的变量i传进函数体内,也就是每一次的i加1之后,会把这个新值放进队列中对应的函数内,于是就解决了这个问题。
2️⃣ 定义一个外部变量:
我们在外部定义一个变量,这样这个变量每一次会被放入队列中,依旧不改变本身的执行机制:
var j = 1;
for (i = 1; i <= 5; i++) {
setTimeout(function () {
alert(j)
j++;
}, 1000);
}
第二种做法,更容易被别人看懂,也更适合做项目时实际使用。
注:setTimeout 返回一个唯一的标识符,我们可以使用 clearTimeout 函数来取消这个定时器。代码如下:
// 延迟 1 秒后输出 "Hello, world!"
const timerId = setTimeout(() => {
console.log("Hello, world!");
}, 1000);
// 取消定时器
clearTimeout(timerId);
这段代码定义了一个 setTimeout 定时器,它会在 1 秒后执行一个函数,输出字符串 “Hello,world!”。同时,它会将返回的计时器 ID 存储在变量 timerId 中。 接下来的一行代码调用了 clearTimeout 函数,并传timerId。这个函数会取消之前设置的定时器,从而避免了执行函数的操作。因此,这段代码最终不会输出任何内容。
setInterval() 也是JavaScript的一个定时器函数,用于设置周期性的定时任务,相较于 setTimeout函数,它就没那么复杂了,但是它的功能确实很强大的,我们先看看它的使用语法:
setInterval(function,times,param1, param2, …);
同setTimeout()格式一致,其中,function参数表示要执行的函数,delay参数表示定时器的时间间隔(以毫秒为单位),param1, param2, …表示传递给函数的参数(可选)。setInterval()函数可以以设置的times为间隔来循环重复function,我们用一个小例子来测试一下:
setInterval(function(){
alert('hello,setInterval()');
}, 1000);
运行之后,每过1秒,就会弹出一个弹窗,显示这段话。
那运行之后,我们想当然会有一个问题,那就是可不可以在某个特定的时机让它不再循环执行?答案是肯定滴,只不过我们需要定义一个setInterval()函数的对象,我们一般取名叫:timer:
var i = 5;
var timer = setInterval(function(){
i --;
if(i < 0){
clearInterval(timer);
}
alert(i);
}, 1000);
上面的代码中,我们给setInterval创建了一个对象叫timer,在外部我们定义了另一个变量i,之后我们每一次执行Interval内的函数时,就让 i-1 ,减到0以下,清除定时器:
clearInterval(timer对象);
上面这句话是清除定时器的代码,传入一个setInterval()函数的对象即可。
✔ 小结:setInterval()和setTimeout()的区别
setInterval() 和 setTimeout() 都是 JavaScript 中的定时器函数,但它们有以下几个区别:
1. setInterval() 在延迟指定时间后重复执行指定任务,直到被取消或页面关闭。而 setTimeout() 在延迟指定时间后执行指定任务,只执行一次;
2. setInterval() 的执行间隔时间是固定的,而 setTimeout() 可以动态调整延迟时间;
3. setInterval() 可能会存在累积性误差,因为它的执行时间是相对于上一次任务结束的时间计算的,如果执行的任务耗时超过了指定的时间间隔,就会出现累积性误差。而 setTimeout() 每次执行都是相对于上一次任务开始的时间计算的,不存在累积性误差;
4. setInterval() 可能会对性能产生影响,因为它会不断地重复执行指定任务,占用 CPU 资源。而 setTimeout() 只会在指定时间后执行一次任务,对性能影响较小。
所以,一般情况下,如果我们需要周期性地执行指定任务,就可以使用 setInterval();如果我们只需要在指定时间后执行一次任务,就可以使用 setTimeout()。
✔ 注意事项
使用setInterval()时要注意以下几点:
1. delay参数的最小值是4毫秒,如果设置的值小于4毫秒,则会被强制转换为4毫秒。
2. setInterval()返回一个定时器ID,可以使用clearInterval()函数来取消定时器。
3. 由于JavaScript是单线程的,因此,如果function函数执行的时间过长,可能会影响页面的响应性能。因此,建议在编写function函数时要尽量减少执行时间。
最后,我们用学习的setTimeout()函数和setInterval()函数联动做一个新年倒计时案例吧:
我们想要这样的效果:
首先,实现在屏幕上展示60秒倒计时;
在倒计时为0后,弹窗展示新年快乐!
有人看了这个说明,觉得那么我们的代码应该是这样的:
var element = document.getElementById("xin-nian")
var clock = 60;
var timer = null;
timer = setInterval(function () {
element.innerHTML = "新年倒计时:" + clock + " !";
console.log(clock)
clock--;
if (clock < 0) {
clearInterval(timer);
alert("新年快乐!");
}
}, 1000);
乍一看,好像没问题,但实际运行的时候,由于向html写入内容有一个小延迟,会导致最后倒计时0这个数字没被写进去就会弹窗,因此,我们要在倒计时最后一秒,用setTimeout()做一个小缓冲:
if (clock < 0) {
clearInterval(timer);
setTimeout(function () {
alert("新年快乐!")
}, 500)};
于是完整的代码应该是这样的:
新年倒计时