JavaScript 定时器
Posted z-meiling
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了JavaScript 定时器相关的知识,希望对你有一定的参考价值。
什么是定时器
- 简单来说就是在一段时间间隔后执行一个函数或执行一段代码的方法
- javascript 原生提供几种定时器
setInterval
、setTimeout
、requestAnimationFrame
- 执行函数中的作用域未全局作用域this指向全局,可通过
bind
方法给执行函数传递参数或指定作用域 (严格模式下,setTimeout( callback,delay)中callback里面的this仍然默认指向window对象, 并不是undefined) - 回调函数会放到 marco task 中等道主线程空闲时才会去执行,因此间隔时间会稍长;调用marco task中的顺序,先进先出原则
setInterval
- 每相隔一段时间间隔执行一个函数或执行一段代码的方法
- 通过
clearInterval
方法来取消定时器
let timerInterID = window.setInterval(callback,delay[,param...])
setTimeout( clearInterval.bind(null,timerInterID),1000)
参数
- callback 重复执行的函数或代码段(不推荐使用一段字符串构成的代码,应为这样做不安全,会被不法分子利用)
- delay 时间间隔,单位为毫秒(ms)实际间隔可能会稍长(最小间隔是4ms)
- timerInterID 每次调用
setInterval
方法返回的唯一 ID,可通过调用clearInterval
方法来清除setInterval
方法 - param1, ..., paramN 传递给执行函数(callback)的参数 ( )
setTimeout
- 在一段时间间隔后执行一个函数或执行一段代码的方法
- 通过
clearTimeout
方法来清除定时器
let timerTimeID = setTimeout(callback,delay[,param1, ..., paramN ])
参数
- callback 重复执行的函数或代码段(不推荐使用一段字符串构成的代码,应为这样做不安全,会被不法分子利用)
- delay 时间间隔,单位为毫秒(ms),默认为0实际间隔可能会稍长(最小间隔为 4ms )
- timerTimeID 每次调用
setTimeout
方法返回的唯一 ID,可通过调用clearTimeout
方法来清除setTimeout
方法 - param1, ..., paramN 传递给执行函数(callback)的参数 ( )
requestAnimationFrame
- 类似于
setInterval
方法,执行动画时推荐使用 - 会在浏览器下次重绘前执行函数
- 执行间隔通常是每秒60次,当运行在后台标签页或隐藏在
iframe
时,会暂停调用
let frameID = window.requestAnimationFrame(callback)
setTimeout(cancelAnimationFrame.bind(null,FrameID),1000)
参数
- callback 更新动画帧所调用的函数
- 一帧大约 16.7ms
兼容性
以上是关于JavaScript 定时器的主要内容,如果未能解决你的问题,请参考以下文章