React-Window 虚拟化滚动

React-Window 使用指南

React-Window ​ 是一个用于高效渲染大型列表和表格数据的 React 库,通过虚拟化滚动技术,只渲染当前可见区域的内容,从而显著提升性能。以下是它的核心用法和官方资源:


1. 官方文档

React-Window 的官方文档非常详细,地址如下:

👉 ​​React-Window 官方文档​

(由库作者 bvaughn维护)

文档包含:

  • API 参考​:所有组件和属性的详细说明。

  • 示例代码​:多种场景的实时演示(如列表、网格、动态高度等)。

  • 性能对比​:与传统渲染方式的性能差异演示。


2. 核心组件与用法

React-Window 提供两个核心组件:

1. ​**FixedSizeList**​(固定高度的列表)

适用于每行高度相同的列表。

复制代码
import { FixedSizeList as List } from 'react-window';

const Row = ({ index, style }) => (
  <div style={style}>Row {index}</div>
);

const ExampleList = () => (
  <List
    height={500}    // 列表可视区域高度
    itemCount={1000} // 总行数
    itemSize={35}    // 每行高度(固定值)
    width={300}      // 列表宽度
  >
    {Row}           // 行渲染组件
  </List>
);
2. ​**VariableSizeList**​(动态高度的列表)

适用于每行高度不同的情况(需提前知道各行高度)。

复制代码
import { VariableSizeList as List } from 'react-window';

const rowHeights = new Array(1000)
  .fill(true)
  .map(() => 25 + Math.round(Math.random() * 50));

const Row = ({ index, style }) => (
  <div style={style}>Row {index} (Height: {rowHeights[index]}px)</div>
);

const ExampleList = () => (
  <List
    height={500}
    itemCount={1000}
    itemSize={index => rowHeights[index]} // 动态获取行高
    width={300}
  >
    {Row}
  </List>
);

3. 其他常用组件

  • ​**FixedSizeGrid** ​ / ​**VariableSizeGrid**​:用于二维表格布局。

  • ​**areEqual** ​:用于优化行组件的渲染(类似 React.memo)。


4. 关键特性

  1. 虚拟化渲染​:仅渲染可视区域内的行,避免 DOM 节点过多。

  2. 平滑滚动​:通过预估滚动位置和动态加载,保持流畅体验。

  3. 支持动态高度 ​:需配合 itemSize函数或外部缓存(如 itemSizeCache)。

  4. 方向控制 ​:支持水平 (layout="horizontal") 或垂直滚动。


5. 常见问题解决

问题 1:动态高度列表闪烁?
  • 原因​:行高未预先计算,滚动时动态调整导致布局抖动。

  • 解决​:

    • 提前测量行高(如通过 itemSize函数返回准确值)。

    • 使用 react-window-infinite-loader分批次加载数据。

问题 2:如何实现无限滚动?
  • 结合 react-window-infinite-loader

    复制代码
    import InfiniteLoader from 'react-window-infinite-loader';
    
    const loadMoreItems = () => { /* 加载更多数据 */ };
    
    <InfiniteLoader
      itemCount={itemCount}
      isItemLoaded={index => items[index]}
      loadMoreItems={loadMoreItems}
    >
      {({ onItemsRendered, ref }) => (
        <List
          ref={ref}
          onItemsRendered={onItemsRendered}
          {/* 其他属性 */}
        />
      )}
    </InfiniteLoader>

6. 替代方案对比

特点
react-window 轻量级(<5KB),适合已知行高的列表/网格
react-virtualized 功能更全(支持自动高度、树形结构等),但体积较大(~15KB)
tanstack-virtual 框架无关(支持 React/Solid/Vue),现代 API 设计

完整示例代码

复制代码
import React from 'react';
import { FixedSizeList as List } from 'react-window';

const data = Array.from({ length: 1000 }, (_, i) => `Item ${i + 1}`);

const App = () => (
  <List
    height={400}
    itemCount={data.length}
    itemSize={50}
    width={300}
  >
    {({ index, style }) => (
      <div style={{ ...style, borderBottom: '1px solid #ccc' }}>
        {data[index]}
      </div>
    )}
  </List>
);

export default App;

总结

  • 使用场景​:长列表、大数据表格、下拉选择框等需要高性能滚动的场景。

  • 性能关键 ​:确保 itemSize准确(动态高度需额外处理),避免行组件不必要的重渲染。

  • 扩展工具 ​:搭配 react-window-infinite-loaderreact-window-scroller满足复杂需求。

如果需要更复杂的交互(如拖拽排序),可以考虑结合 react-dnd等库实现。

相关推荐
JustHappy4 小时前
古法编程秘籍(七):互联网到底是什么?把两台电脑怎么说话搞懂就够了
前端·后端·网络协议
snow@li4 小时前
SEO-文章标题:写文章时候,分类+主标题+大纲+解释 作为标题 / 不点进去也知道全文覆盖什么 / 标题即架构
前端
kyriewen5 小时前
Git Commit 前自动修复代码风格?配置 Husky + lint-staged,从此 CR 只聊逻辑
前端·git·面试
小和尚同志5 小时前
AI 自动化测试探索(一):Playwright MCP
前端·人工智能·aigc
老马识途2.05 小时前
在AI的帮助下理解spring的启动过程
java·前端·spring
徐小夕6 小时前
Loop Engineering 深度解析与实战指南(全网最全)
前端·算法·github
运筹vivo@6 小时前
Python ContextVar 底层机制与内存模型拆解
前端·数据库·python
#麻辣小龙虾#7 小时前
基于vue3.0开发一款【固废与废气运维管理系统】(支持源码)
前端·vue.js·vue3
Cosolar7 小时前
Docsify零构建文档站完全指南:从快速搭建到企业级部署
前端·开源·github
weixin_471383038 小时前
Taro-02-页面路由
前端·taro