首页 > web前端 > js教程 > 正文

React渲染大量数据导致页面卡顿闪烁怎么办?

花韻仙語
发布: 2025-03-04 08:34:18
原创
993人浏览过

react渲染大量数据导致页面卡顿闪烁怎么办?

React大数据渲染优化:RequestIdleCallback API高效解决页面卡顿和闪烁

React应用渲染大量数据时,常出现页面卡顿或闪烁。本文介绍如何利用requestIdleCallback API优化渲染效率,尤其适用于数据项高度不固定、难以使用虚拟列表优化的场景。

问题根源在于一次性渲染所有数据超出了浏览器处理能力,导致渲染阻塞。解决方案是将数据分批处理,利用浏览器空闲时间逐步渲染。

以下是一个自定义Hook usePerformTask,它巧妙地运用requestIdleCallback:

const usePerformTask = <T>(data: T[], run: (batch: T[]) => void, batchSize = 10) => {
  const dataRef = useRef(data);
  useEffect(() => {
    dataRef.current = data;
  }, [data]);

  useEffect(() => {
    let isCancelled = false;
    const performTask = (deadline: IdleDeadline) => {
      while (!isCancelled && dataRef.current.length > 0 && deadline.timeRemaining() > 0) {
        const batch = dataRef.current.splice(0, batchSize);
        run(batch);
      }

      if (!isCancelled && dataRef.current.length > 0) {
        requestIdleCallback(performTask);
      }
    };
    requestIdleCallback(performTask);

    return () => {
      isCancelled = true;
    };
  }, [batchSize]);
};
登录后复制

此Hook接收三个参数:data(待渲染数据数组)、run(处理数据批次的函数)、batchSize(每次处理的数据量)。它使用useRef跟踪数据,useEffect控制渲染过程。

核心逻辑在performTask函数中:它在浏览器空闲时,每次处理batchSize数量的数据,并用deadline.timeRemaining()判断剩余时间,避免阻塞主线程。 数据未处理完则递归调用requestIdleCallback,直至所有数据渲染完毕。isCancelled变量用于处理组件卸载,防止不必要的计算。

通过这种分批处理,有效避免页面闪烁,提升用户体验。

以上就是React渲染大量数据导致页面卡顿闪烁怎么办?的详细内容,更多请关注php中文网其它相关文章!

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
相关标签:
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号