前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >requestIdleCallback方法

requestIdleCallback方法

作者头像
蓓蕾心晴
发布2022-10-27 15:09:51
7230
发布2022-10-27 15:09:51
举报
文章被收录于专栏:前端小叙前端小叙

概念

window.requestIdleCallback() 方法插入一个函数,这个函数将在浏览器空闲时期被调用。这使开发者能够在主事件循环上执行后台和低优先级工作,而不会影响延迟关键事件,如动画和输入响应。函数一般会按先进先调用的顺序执行,然而,如果回调函数指定了执行超时时间timeout,则有可能为了在超时前执行函数而打乱执行顺序。 你可以在空闲回调函数中调用 requestIdleCallback(),以便在下一次通过事件循环之前调度另一个回调。 var handle = window.requestIdleCallback(callback[, options]) 返回值 一个 ID,可以把它传入 Window.cancelIdleCallback() 方法来结束回调。 参数 callback 一个在事件循环空闲时即将被调用的函数的引用。函数会接收到一个名为 IdleDeadline 的参数,这个参数可以获取当前空闲时间以及回调是否在超时时间前已经执行的状态。 options可选 包括可选的配置参数。具有如下属性:

  • timeout:如果指定了 timeout,并且有一个正值,而回调在 timeout 毫秒过后还没有被调用,那么回调任务将放入事件循环中排队,即使这样做有可能对性能产生负面影响。

https://developer.mozilla.org/zh-CN/docs/Web/API/Window/requestIdleCallback

通俗点理解,requestIdleCallback 是为了让占用时间的任务放在一个事件循环中空闲时间去执行,而不影响主线程任务的执行,如用户交互、输入等,如果一个事件循环中空闲时间用完,则进入下次事件循环,继续在空闲时间执行。

demo

不使用 requestIdleCallback 直接执行一个耗时的循环,会导致另一个按钮点击后一直无法应用渲染,直到循环执行结束后,才可生效。

代码语言:javascript
复制
<!DOCTYPE html>
<html lang="en">
    <head>
        <meta charset="UTF-8" />
        <meta http-equiv="X-UA-Compatible" content="IE=edge" />
        <meta name="viewport" content="width=device-width, initial-scale=1.0" />
        <title>Document</title>
    </head>
    <body>
        <style>
            #box {
                padding: 20px;
                background: palegoldenrod;
            }
        </style>

        <!-- body -->
        <div id="box"></div>
        <button id="btn1">执行计算任务</button>
        <button id="btn2">更改背景颜色</button>
        <script>
            const box = document.getElementById("box");
            const btn1 = document.getElementById("btn1");
            const btn2 = document.getElementById("btn2");

            let number = 999999;
            let value = 0;

            function calc() {
                while (number > 0) {
                    value = Math.random() < 0.5 ? Math.random() : Math.random();
                    console.log(value);
                    number--;
                }
            }

            btn1.onclick = function () {
                calc();
            };

            btn2.onclick = function () {
                box.style.background = "green";
            };
        </script>
    </body>
</html>

使用  requestIdleCallback 后,另一个按钮点击渲染的工作不受影响。

代码语言:javascript
复制
<style>
    #box {
        padding: 20px;
        background: palegoldenrod;
    }
</style>
<!-- body -->
<div id="box"></div>
<button id="btn1">执行计算任务</button>
<button id="btn2">更改背景颜色</button>
<script>
    const box = document.getElementById("box");
    const btn1 = document.getElementById("btn1");
    const btn2 = document.getElementById("btn2");

    let number = 999999;
    let value = 0;

    function calc(deadline) {
        // deadline.timeRemaining() 等于 0 之后 循环就停止了,必须在 deadline.timeRemaining() 时间内执行,否则还是会阻塞,
        while (number > 0 && deadline.timeRemaining() > 0) {
            value = Math.random() < 0.5 ? Math.random() : Math.random();
            number--;
        }
        // 所以这里需要再次调用,再下次主线程任务开始后寻找空闲时间来执行
        requestIdleCallback(calc);
    }

    btn1.onclick = function () {
        requestIdleCallback(calc);
    };

    btn2.onclick = function () {
        box.style.background = "green";
    };
</script>

参考:https://juejin.cn/post/6993973502852202503

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2022-10-09,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 概念
  • demo
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档