千家信息网

JavaScript的setTimeout和setInterval怎么用

发表于:2025-01-20 作者:千家信息网编辑
千家信息网最后更新 2025年01月20日,这篇文章主要讲解了"JavaScript的setTimeout和setInterval怎么用",文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习"JavaSc
千家信息网最后更新 2025年01月20日JavaScript的setTimeout和setInterval怎么用

这篇文章主要讲解了"JavaScript的setTimeout和setInterval怎么用",文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习"JavaScript的setTimeout和setInterval怎么用"吧!

I. 总述

首先,setTimeout()和setInterval()函数是JavaScript中两个很重要的关于"时间的函数",因此,我们在学习JavaScript的过程中,一定要对这两个函数有一个深入的学习,它们两个函数也是经常被使用!

其中,如果分别用一句话来概括这两个函数,那么应该是这样的:

setTimeout(): 该函数能够按照设定的时间值延迟执行其中的事件。

setInterval(): 该函数能够按照设定的时间值作为间隔,周期性的执行其中的时间。

当然了,只是简述,细节方面,我们在下面的部分给大家做讲解。

II. setTimeout()函数

首先是我们的setTimeout()函数,它的格式是怎么样的呢:

setTimeout(function,times);

是的,就是这么简单的格式,其中,我们需要两个参数,分别是一个函数和一个int值函数表示延迟一段时间后要执行的函数体,int值就是我们说的这段时间,例如我们看这段简单的代码:

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 吗?

然而实际上是这样的:【点我揭晓】

也就是,它输出了5 5 5 5 5,所以这是为什么呢?因为setTimeout()是一个异步执行函数,说人话就是,它里面的函数体,并不会在每一次执行的时候立刻运行,而是会丢进执行队列中,等待"主线任务"全部完成,才会执行它

于是在5次for循环后,i的值是5,传进去,弹出了5个5。

那么有没有解法呢?我给大家两种解法:

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);}

第二种做法,更容易被别人看懂,也更适合做项目时实际使用。

III. setInterval()函数

第二个函数setInterval()就没那么复杂了,但是它的功能确实很强大的,我们先看看它的使用格式

setInterval(function,times);

依旧是两个参数,同setTimeout()格式一致,它可以以设置的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()函数的对象即可。

IV. 新年倒计时案例

最后,我们用学习的setTimeout()函数和setInterval()函数联动做一个新年倒计时案例吧:

我们想要这样的效果:

首先,实现在屏幕上展示60秒倒计时;

在倒计时为0后,弹窗展示新年快乐!

有人看了这个说明,觉得那么我们的代码应该是这样的:

var element = document.getElementById("xin-nian")var clock = 60;var timer = null;timer = setInterval(function () {    element[xss_clean] = "新年倒计时:" + clock + " !";    console.log(clock)    clock--;    if (clock < 0) {        clearInterval(timer);        alert("新年快乐!");    }}, 1000);

乍一看,好像没问题,但实际运行的时候,由于向html写入内容有一个小延迟,会导致最后倒计时0这个数字没被写进去就会弹窗,因此我们要在倒计时最后一秒,用setTimeout()做一个小缓冲

if (clock < 0) {    clearInterval(timer);    setTimeout(function () {        alert("新年快乐!")    }, 500)}

于是完整的代码应该是这样的:

                 新年倒计时         

实现的效果是下面这样的动图

感谢各位的阅读,以上就是"JavaScript的setTimeout和setInterval怎么用"的内容了,经过本文的学习后,相信大家对JavaScript的setTimeout和setInterval怎么用这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是,小编将为大家推送更多相关知识点的文章,欢迎关注!

函数 倒计时 两个 代码 时间 学习 变量 就是 运行 快乐 对象 格式 问题 延迟 内容 实际 队列 循环 输出 也就是 数据库的安全要保护哪些东西 数据库安全各自的含义是什么 生产安全数据库录入 数据库的安全性及管理 数据库安全策略包含哪些 海淀数据库安全审计系统 建立农村房屋安全信息数据库 易用的数据库客户端支持安全管理 连接数据库失败ssl安全错误 数据库的锁怎样保障安全 朝阳云科网络技术有限公司 阴阳师还有春之樱服务器吗 苹果手机手动网络安全性 服务器是指 数据库接口与技术 初级软件开发工程师最初薪资 儿童节网络安全宣传语 页面ajax加载数据库 网络安全人员培训试题 软件开发年收入3亿 昌平区口碑好的软件开发诚信服务 数据库相关的职业岗位有哪些 总工会网络安全宣传简报 湖北文理学院邮件服务器 南关区智能化网络技术咨询哪家好 海淀区应用软件开发供应 数据库系统基础电子版 为什么苹果服务器访问不通 行业网络安全论文 重庆大学网络技术处长 网线网络安全低怎么处理 儿童节网络安全宣传语 云服务器搭建全部步骤 数据库相关的职业岗位有哪些 网络安全工作是做什么的 海智网聚网络技术公司 对无线网络技术的独立看法 大学计算机网络技术认知报告 数据库原理是计算机吗 服务器硬盘一直显示不正常
0