react性能优化比较好的办法有哪些?

一、最核心:减少不必要的渲染

这是 React 性能优化的本质。

1. React.memo

函数组件避免重复渲染:

复制代码
const MyComponent = React.memo((props) => {
  return <div>{props.value}</div>
})

👉 适用于:

  • props 不常变

  • 纯展示组件


2. useMemo(缓存计算结果)

复制代码
const computed = useMemo(() => {
  return heavyCalculation(data)
}, [data])

👉 适用于:

  • 大数据计算(比如表格过滤、排序)

  • Echarts 数据处理

⚠️ 注意:不要滥用,小计算没必要


3. useCallback(缓存函数)

复制代码
const handleClick = useCallback(() => {
  doSomething()
}, [])

👉 解决问题:

  • 避免子组件因为函数引用变化而重新渲染

二、列表性能优化(你这个场景重点)

4. 虚拟列表(强烈推荐)

用库:

  • react-window

  • react-virtualized

👉 场景:

  • 表格 1000+ 行

  • 日志列表

  • 性能数据列表

👉 核心思想:

👉 只渲染可视区域!


5. key 使用正确

复制代码
list.map(item => <Row key={item.id} />)

❌ 不要用 index:

复制代码
key={index}

👉 否则会导致 diff 失效 → 频繁重排


三、组件拆分策略

6. 拆小组件(非常重要)

❌ 错误:

复制代码
一个大页面组件 = 所有状态

✅ 正确:

  • 表格组件

  • 筛选组件

  • 图表组件

👉 好处:

  • 局部更新

  • 更容易用 memo


四、状态管理优化

7. 避免无意义的 state

❌:

复制代码
const [value, setValue] = useState(props.value)

👉 会造成:

  • 双状态同步问题

  • 多余 render


8. 状态下沉 or 提升

👉 原则:

  • 谁用谁管理

  • 避免"全局 state 导致全局 re-render"


五、异步 & 请求优化

9. 防抖 / 节流

搜索场景:

复制代码
import debounce from 'lodash/debounce'

👉 避免频繁请求接口


10. 请求缓存

用:

  • React Query

  • SWR

👉 优势:

  • 自动缓存

  • 减少重复请求

  • 自动刷新


六、代码层面优化

11. 懒加载(代码分割)

复制代码
const Page = React.lazy(() => import('./Page'))

👉 配合:

复制代码
<Suspense fallback={<Loading />}>

👉 好处:

  • 减少首屏体积

12. Tree Shaking

👉 确保:

复制代码
import { Button } from 'antd'

而不是:

复制代码
import * as antd from 'antd'

七、Echarts / 图表优化(你项目重点)

👉 常见问题:图表卡顿

优化:

13. 避免重复 setOption

复制代码
chart.setOption(option, { notMerge: true })

14. 数据分批渲染

👉 大数据:

  • 分页

  • 抽样


15. resize 防抖


八、性能分析工具(非常关键)

16. React DevTools Profiler

👉 看:

  • 哪个组件 render 最多

  • render 时间


17. Chrome Performance

👉 查:

  • JS 执行时间

  • 卡顿原因


九、一个实战总结(重点给你)

你现在的"性能平台"项目,建议优先做这几个:

👉 优先级排序(非常重要):

  1. ✅ 虚拟列表(提升最大)

  2. ✅ React.memo + useCallback

  3. ✅ 数据缓存(React Query)

  4. ✅ Echarts 优化

  5. ✅ 防抖请求

  6. ✅ 组件拆分


最后给你一句实战经验

👉 80% 的性能问题 = 不必要的 render

而不是 JS 太慢。

相关推荐
ZC跨境爬虫1 分钟前
跟着 MDN 学CSS day_13 :(深入理解CSS中的元素尺寸调整)
前端·javascript·css·ui·html·tensorflow
L、2185 分钟前
CANN ops-transformer 仓库详解:Transformer 算子的底层实现与性能优化
深度学习·性能优化·transformer
threelab24 分钟前
Three.js 加载 3D Tiles 瓦片数据 | 三维可视化 / AI 提示词
开发语言·前端·javascript·人工智能·3d·着色器
百度地图开放平台39 分钟前
我用百度地图 Skills 体系重构了物流调度系统,节省了 90% 的人力
前端·github
JavaAgent架构师1 小时前
前端AI工程化(九):AI Agent平台前端架构设计
前端·人工智能
梦想CAD控件1 小时前
网页端对DWG图纸进行预览与批注(CAD轻量化)
java·前端·javascript
不吃土豆的马铃薯2 小时前
Spdlog 进阶:日志基本控制、日志格式控制、异步记录器
linux·服务器·开发语言·前端·c++
wait2 小时前
Vibe Coding 开发技巧
前端·javascript·人工智能
ZengLiangYi2 小时前
Vercel AI SDK 入门:一行代码切换 LLM Provider
前端·javascript·aigc
qq_283720052 小时前
万字深度:Chroma 向量数据库全解析 — 核心原理、实战操作、性能优化与工程最佳实践
数据库·性能优化