【JS】执行机制解析,设置定时器、取消定时器

目录

JavaScript 执行机制

JavaScript 定时器

1、setTimeout()

2、setInterval() 

3、setImmediate()

4、requestAnimationFrame()

5、clearTimeout() 取消定时器

6、 clearInterval()取消定时器

6、使用setTimeout模拟setInterval行为

setInterval与setInterval的区别


JavaScript 执行机制

浏览器( JavaScript 引擎)执行 JavaScript 的机制是基于事件循环的。由于 JavaScript 是单线程,同一时间只能执行一个任务。为了避免某些长时间任务造成无意义等待,JavaScript 引入了异步概念。

同步任务直接在主线程队列中顺序执行,而异步任务会进入另一个任务队列,不会阻塞主线程。等到主线程队列空了(执行完了)的时候,就会去异步队列查询是否有可执行的异步任务了(异步任务通常进入异步队列之后还要等一些条件才能执行,如 ajax 请求文件读写),如果某个异步任务可以执行了便加入主线程队列,以此循环。

JavaScript 定时器

定时器也是一种异步任务,通常浏览器都有一个独立的定时器模块,定时器的延迟时间就由定时器模块来管理,当某个定时器到了可执行状态,就会被加入主线程队列。

另外,多个定时器如不及时清除clearTimeout()),会造成干扰,使延迟时间更加捉摸不透。所以,不管定时器有没有执行完,要及时清除不需要的定时器。

1、setTimeout()

设置一个定时器,在定时器到期后执行一次函数或代码段:setTimeout(fn, x) 表示延迟 x 毫秒之后执行 fn

var timeoutId = setTimeout(code, delay, param1, param2, ...)
var timeoutId = setTimeout(func, delay, param1, param2, ...)
  • timeoutId 定时器ID
  • func 延迟后执行的函数
  • code 延迟后执行的代码字符串,不推荐使用
  • delay 延迟的时间(单位:毫秒),默认值为0
  • param1,param2 向延迟函数传递而外的参数,IE9以上支持 
  1. HTML5 规范规定最小延迟时间不能小于 4ms ,即 <
  • 2
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
HTML页面退出关闭定时器: 在HTML页面中,当你离开或者关闭页面时,应该清除所有的定时器以释放内存,可以使用以下代码实现: ```javascript window.onbeforeunload = function(){ clearInterval(timer);//清除定时器 } ``` JavaScript设置定时器: JavaScript中有两种定时器:setInterval() 和 setTimeout()。setInterval() 方法会按照指定周期(以毫秒计)来调用函数,setTimeout() 方法会在指定的时间后执行一次。 setInterval() 语法: ```javascript var intervalID = window.setInterval(func, delay, [param1, param2, ...]); ``` setTimeout() 语法: ```javascript var timeoutID = window.setTimeout(func, delay, [param1, param2, ...]); ``` 取消定时器: 使用clearInterval() 或 clearTimeout() 方法可以取消定时器。 clearInterval() 语法: ```javascript window.clearInterval(intervalID); ``` clearTimeout() 语法: ```javascript window.clearTimeout(timeoutID); ``` 执行机制解析: setInterval() 和 setTimeout() 方法使用了 JavaScript 的事件循环机制。在 JavaScript 中,事件循环会不断地从任务队列中取出任务并执行,当任务队列为空时,事件循环会一直等待新的任务加入。 setInterval() 和 setTimeout() 方法会把回调函数推入任务队列,当时间到达后,事件循环会执行这个任务。setInterval() 方法会不断地将同一个任务推入任务队列,直到使用 clearInterval() 方法取消定时器。setTimeout() 方法只会推入一个任务,执行后就结束了。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

阿昊在

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值