JavaScript中计时器requestAnimationFrame、setTimeout、setInterval、setImmediate的使用和区别

yizhihongxing

在JavaScript中,我们经常使用requestAnimationFramesetTimeoutsetIntervalsetImmediate来控制代码的执行时机。它们各有特点和适用场景:

1. requestAnimationFramerequestAnimationFrame主要用于浏览器动画渲染。这个函数允许你在下一次浏览器重绘前调用一个函数。它提供了一个高精度的时间戳,可以在函数内部使用。由于浏览器可以在重绘前执行动画,这可以提高动画效果的性能。

使用:

function animate() {
  // 动画逻辑
  requestAnimationFrame(animate);
}
requestAnimationFrame(animate);

2. setTimeoutsetTimeout用于在指定的时间后执行一次回调函数。它返回一个timeoutID,可以用来取消这个计时器。

使用:

const timeoutID = setTimeout(function() {
  // 任务代码
}, 2000); // 2秒后执行

// 取消计时器
clearTimeout(timeoutID);

3. setIntervalsetInterval用于每隔一定时间间隔重复执行回调函数。它同样返回一个intervalID,可以用来取消这个计时器。

使用:

const intervalID = setInterval(function() {
  // 任务代码
}, 1000); // 每隔1秒执行一次

// 取消计时器
clearInterval(intervalID);

4. setImmediatesetImmediate的功能类似于setTimeout,但是它会在当前事件循环结束后立即执行回调函数,而不是等待指定的时间。需要注意的是,setImmediate并不是所有浏览器都支持,主要用于Node.js环境。

使用(Node.js环境):

const immediateID = setImmediate(function() {
  // 任务代码
});

// 取消立即执行
clearImmediate(immediateID);

 

这四个方法的执行时机有所不同:

1. requestAnimationFrame

requestAnimationFrame 的执行时机是在浏览器准备好绘制下一帧屏幕时,也就是在浏览器每次重绘页面之前。这样可以让动画更加流畅,并且避免不必要的计算。当页面处于隐藏状态时,requestAnimationFrame 不会运行,这样可以减少资源的浪费。

2. setTimeout

setTimeout 的执行时机是在指定的延迟时间之后,只会执行一次。具体执行时间可能会因为浏览器当前的工作负载而有所偏差。

3. setInterval

setInterval 的执行时机是在指定的时间间隔之后,每隔指定的时间就会执行一次,直到被清除。

4. setImmediate

setImmediate 的执行时机是在当前事件循环迭代结束后立即执行,相当于将回调函数插入到事件队列的头部。

综上所述,requestAnimationFrame 的执行时机与浏览器的重绘时间有关,setTimeout setInterval 的执行时机与指定的时间间隔有关,而 setImmediate 的执行时机则是在当前事件循环迭代结束后立即执行。

 

这四个方法之间的区别如下:

1. requestAnimationFrame

- 用于动画效果的开发,以优化动画的性能。
- 在浏览器准备好绘制下一帧屏幕时调用传入的回调函数。
- 不会在页面隐藏或最小化时运行,从而减少资源浪费。
- 调用频率与屏幕刷新率同步,可以提供平滑的动画效果。

2. setTimeout

- 延迟一定时间后调用传入的回调函数。
- 仅调用一次。
- 时间精度不太准确,会受到浏览器当前忙碌程度的影响。
- 用于创建简单的计时器、轮询和非重要操作。

3. setInterval

- 在一定时间间隔后调用传入的回调函数,直到被清除。
- 可以用于创建重复执行的计时器、轮询和非重要操作。
- 时间精度不太准确,同样会受到浏览器当前忙碌程度的影响。

4. setImmediate

- 在当前事件循环迭代结束后立即执行传入的回调函数。
- 相当于将回调函数插入到事件队列的头部。
- 用于在一些异步操作完成后立即执行回调函数。

 

总体而言,requestAnimationFrame 适用于动画开发,setTimeout setInterval 适用于计时器、轮询等需要延迟执行的操作,而 setImmediate 则适用于需要立即执行的回调函数。

 

原文链接:https://www.cnblogs.com/ronaldo9ph/p/17284643.html

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:JavaScript中计时器requestAnimationFrame、setTimeout、setInterval、setImmediate的使用和区别 - Python技术站

(0)
上一篇 2023年4月18日
下一篇 2023年4月18日

相关文章

  • JavaScript 对象管家 Proxy

    JavaScript 对象管家 Proxy 的完整攻略 Proxy 概述 Proxy 是 ES6 所引入的一个内置对象,它用于通过一个代理来控制对另一个对象(目标对象)的访问。被代理的对象可以是任意一个对象。通过定义一系列的 trap 方法,可以在代理对象访问目标对象时截获操作并进行相应处理。 Proxy 的基本使用 在代码中使用 Proxy 时,首先需要创…

    JavaScript 2023年5月28日
    00
  • JS实现的缓冲运动效果示例

    下面是关于JS实现缓冲运动效果的完整攻略: 什么是缓冲运动效果 缓冲运动效果是一种动画效果,比普通的匀速运动更加流畅自然,因为在运动中不会做出跳跃式的运动。当元素移动到接近目的地时,移动速度就会减缓,直到移动到目的地。 JS实现缓冲运动效果 JS实现缓冲运动效果的基本思路是,在每个时间间隔的运动过程中,元素移动的距离都是当前移动距离的一部分,这个部分可以通过…

    JavaScript 2023年6月10日
    00
  • JS将指定的某个字符全部转换为其他字符实例代码

    下面是完整的攻略,包含了示例代码和说明: 思路: 我们可以通过JS的字符串处理方法,将指定字符串中的某个字符全部替换为其他字符。具体而言,我们可以使用字符串的replace()函数实现替换功能,该函数接受两个参数,分别表示要替换的字符和用于替换的字符。 下面是基本的replace()函数语法: str.replace(searchValue, replace…

    JavaScript 2023年5月28日
    00
  • JavaScript中的标签语句用法分析

    接下来我分享一下“JavaScript中的标签语句用法分析”的完整攻略: 什么是标签语句 在JavaScript中,标签语句是一种向代码块添加标记的机制。它使用标签来标识某个特定的代码块,从而使我们能够在代码中方便地跳转和执行特定的代码块。常见的标签语句可以使用break和continue语句来使用。 标签语句的基本语法如下: label : stateme…

    JavaScript 2023年5月18日
    00
  • 举例讲解JavaScript substring()的使用方法

    下面我将为你详细讲解“举例讲解JavaScript substring()的使用方法”的完整攻略,包含以下内容: substring()方法的概述 substring()方法的语法 substring()方法的参数 substring()方法的返回值 substring()方法的示例说明 总结 1. substring()方法的概述 substring()是…

    JavaScript 2023年5月28日
    00
  • JavaScript常用字符串与数组扩展函数小结

    JavaScript是一门强大的语言,它提供了大量的内置函数,其中包括对字符串和数组的操作。除此之外,还有很多扩展函数可以用于处理字符串和数组。 本文将对常用的JavaScript字符串和数组扩展函数做一个小结。 JavaScript字符串扩展函数 1. startsWith() startsWith()方法用于判断一个字符串是否以指定的字符串开头。如果是,…

    JavaScript 2023年5月27日
    00
  • javascript表单事件处理方法详解

    JavaScript表单事件处理方法详解 什么是表单事件 表单事件是指当用户与表单元素交互时,浏览器会触发一些事件以响应用户的行为。表单事件可以是用户输入、用户点击、用户提交表单等等。 常见的表单事件 以下是一些常见的表单事件: focus:当元素获得焦点时 blur:当元素失去焦点时 change:当元素值发生改变时 keydown、keyup:按下或松开…

    JavaScript 2023年6月10日
    00
  • javascript中replace使用方法总结

    JavaScript中replace使用方法总结 replace()方法是JavaScript中字符串对象的一个常用方法,其作用是在字符串中搜索指定的子字符串或者正则表达式,并将其替换为新的子字符串。在本篇文章中,我们将对replace()方法进行详细的讲解和总结。 基本使用 replace()方法的基本语法如下: string.replace(search…

    JavaScript 2023年5月28日
    00
合作推广
合作推广
分享本页
返回顶部