当前位置: 首页 > wzjs >正文

济南网站优化公司艾乎网湖南 seo

济南网站优化公司艾乎网,湖南 seo,网站域名费用怎么做帐,jsp mysql开发网站开发深入解析 requestAnimationFrame 和 requestIdleCallback requestAnimationFrame (rAF) 和 requestIdleCallback (rIC) 都是浏览器提供的 异步调度 API,但它们的执行时机和用途完全不同。 API主要用途何时执行是否保证执行适合场景requestAnimationFrame高优先级 U…

深入解析 requestAnimationFramerequestIdleCallback


requestAnimationFrame (rAF)requestIdleCallback (rIC) 都是浏览器提供的 异步调度 API,但它们的执行时机和用途完全不同。

API主要用途何时执行是否保证执行适合场景
requestAnimationFrame高优先级 UI 更新下一帧渲染前(通常 16.67ms 内)一定执行(下一帧到来时)动画、滚动、WebSocket 实时数据可视化
requestIdleCallback低优先级任务浏览器空闲时(时间不确定)不一定执行(如果浏览器一直忙)预加载、日志统计、AI 计算、非关键数据处理

1. requestAnimationFrame (rAF):下一帧渲染前执行

🔹 工作原理

浏览器的 渲染帧率 一般是 60Hz,即 每 16.67ms 需要完成一次绘制(包括 JS 计算、样式计算、布局、绘制等)。

  • requestAnimationFrame 会在下一帧开始前执行,保证代码在下一帧渲染前完成,不会阻塞 UI
  • 适用于 高频 UI 更新,比如:
    • CSS 动画
    • 页面滚动
    • WebSocket 高频推送的数据可视化
    • Canvas 绘图

🔹 示例 1:流畅动画

let box = document.getElementById("box");
let position = 0;function move() {position += 5;box.style.transform = `translateX(${position}px)`;if (position < 300) {requestAnimationFrame(move); // 递归调用,持续更新}
}requestAnimationFrame(move);

为什么使用 requestAnimationFrame

  • 不卡顿:会在合适的时间点执行,不会阻塞主线程。
  • 不影响页面性能:浏览器空闲时自动暂停,节省资源。

🔹 示例 2:WebSocket 高频推送数据

let pending = false;socket.onmessage = (event) => {const data = JSON.parse(event.data);if (!pending) {pending = true;requestAnimationFrame(() => {updateUI(data);pending = false;});}
};function updateUI(data) {document.getElementById("output").innerText = JSON.stringify(data);
}

📌 避免 UI 频繁更新,导致卡顿

  • 如果 WebSocket 每 1ms 推送一次数据,直接更新 DOM 会让页面卡死。
  • 使用 requestAnimationFrame 让 UI 更新保持在 60FPS 以内,保证流畅度。

🔹 示例 3:滚动优化

监听 scroll 事件时,直接操作 DOM 可能导致页面卡顿,应该用 requestAnimationFrame 优化:

let ticking = false;window.addEventListener("scroll", () => {if (!ticking) {requestAnimationFrame(() => {updateScrollPosition(window.scrollY);ticking = false;});ticking = true;}
});function updateScrollPosition(scrollY) {document.getElementById("position").innerText = scrollY;
}

📌 好处:避免 scroll 事件触发过于频繁,优化滚动时的 UI 更新。


2. requestIdleCallback (rIC):浏览器空闲时执行

🔹 工作原理

  • requestIdleCallback 让浏览器在 主线程空闲时 执行低优先级任务。
  • 执行时间不固定,取决于浏览器的空闲情况:
    • 如果用户在快速滚动,可能不会触发 requestIdleCallback
    • 如果 CPU 负载高,可能很久都不会执行。

🔹 示例 1:处理后台任务

function heavyTask(deadline) {while (deadline.timeRemaining() > 0) {console.log("执行低优先级任务...");}requestIdleCallback(heavyTask);
}requestIdleCallback(heavyTask);

📌 deadline.timeRemaining() 返回本次空闲时间的剩余毫秒数,避免影响 UI 交互。


🔹 示例 2:懒加载数据

当页面加载完毕后,在空闲时间预加载一些不重要的数据:

requestIdleCallback(() => {fetch("/api/data").then(res => res.json()).then(data => {console.log("预加载数据完成:", data);});
});

📌 好处:不影响页面主线程,提高用户体验。


🔹 示例 3:日志上报

requestIdleCallback(() => {sendAnalyticsData();
});

📌 好处:浏览器空闲时再上传日志,避免影响用户体验。


3. requestAnimationFrame vs requestIdleCallback:何时用哪一个?

场景requestAnimationFramerequestIdleCallback
动画✅ 需要流畅动画❌ 不能保证执行时间
高频 WebSocket 数据✅ 控制 UI 更新频率❌ 可能无法及时更新
页面滚动✅ 监听 scroll 事件❌ 不能保证执行时机
后台任务(日志、数据计算)❌ 影响 UI 体验✅ 浏览器空闲时执行
预加载数据❌ 影响用户交互✅ 在用户空闲时加载
AI 计算❌ 主线程压力大✅ 只有空闲时才执行

4. 如何组合使用?

🔹 WebSocket 高速数据流 + UI 更新优化

let pending = false;
let backgroundData = [];socket.onmessage = (event) => {const data = JSON.parse(event.data);backgroundData.push(data);// 让 UI 更新不超过 60FPSif (!pending) {pending = true;requestAnimationFrame(() => {updateUI(backgroundData);backgroundData = [];pending = false;});}// 在浏览器空闲时处理日志requestIdleCallback(() => {processLogs(backgroundData);});
};function updateUI(data) {console.log("更新 UI", data);
}function processLogs(data) {console.log("后台处理数据", data);
}

📌 优化点

  1. requestAnimationFrame 让 UI 更新流畅,不会因 WebSocket 高频推送导致页面卡死
  2. requestIdleCallback 在浏览器空闲时处理日志,避免影响 UI 渲染

5. 总结

  • requestAnimationFrameUI 渲染优化,适用于 动画、滚动、WebSocket UI 更新
  • requestIdleCallback后台任务调度,适用于 日志、预加载、AI 计算
  • 两者结合使用,可以优化高性能应用,提升页面流畅度和用户体验! 🚀
http://www.dtcms.com/wzjs/140411.html

相关文章:

  • 做动漫网站如何应用数据绑定杭州seo网站
  • 微信公众号做公司网站百度搜索怎么优化
  • 学校的网站怎么做的搜索图片
  • 动态网站建设与维护外贸公司如何做推广
  • 网站是用dw做的吗百度seo自动优化
  • 网站策划书哪个容易做seo广告优化多少钱
  • 兰溪网站建设学徒北京网站推广公司
  • 深圳松岗 网站建设镇江推广公司
  • 什么是网络营销宏观环境因素网站优化排名易下拉软件
  • 之前做的网站说要升级六年级下册数学优化设计答案
  • 公司产品网站应该怎么做上海优化网站公司哪家好
  • 淮北做网站的公司有哪些引流用什么话术更吸引人
  • 西安政府网站开发公司外贸网站设计
  • 河北手机网站制作企业如何获取网站的seo
  • 东莞住房和城乡建设厅网站百度2022新版下载
  • 做蛋糕网站有哪些怎么宣传自己的店铺
  • b2c网站建设方案seo课程总结怎么写
  • 做阿里巴巴网站电话网站建设seo
  • 廉洁文化建设网站买卖网站
  • 番禺网站制作价格重庆seo点击工具
  • 中山建设招聘信息网站抖音seo关键词排名技术
  • 如何做酒网站产品推广软文500字
  • 厦门 网站建设公司seo推广营销网站
  • 做网站怎么做放大图片怎么进行网站关键词优化
  • 情趣官方网站怎么做代理外链发布平台大全
  • wordpress 百度cdn无锡seo优化公司
  • 网站开发者模式个人网站搭建
  • 网站内容设计是什么东莞网站建设制作
  • 新网站建设验收广州番禺发布网
  • 成品影视app开发工具seo引擎优化外包