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 太慢。

相关推荐
fix一个write十个5 小时前
从零搭建音视频通话太痛苦?这个 Vue3 CallKit 让你 5 分钟搞定 1v1 + 群聊通话
前端·vue.js·github
豹哥学前端5 小时前
告别割裂式学习:待办清单项目,一次性掌握数组、本地存储与事件委托
前端·javascript
JYeontu5 小时前
照片墙太死板?做一个会随风摇摆的绳串图片交互效果
前端·javascript·css
2501_915921435 小时前
HTTPS前端劫持 新一代流量劫持解决方案
前端·网络协议·ios·小程序·https·uni-app·iphone
Yue栎廷5 小时前
邪修:Markdown加粗语法**本土化改造
前端·javascript·人工智能
爱怪笑的小杰杰5 小时前
优化 UniApp 日历组件的多语言切换:告别 setLocale 引起的 App 重启
java·前端·uni-app
有所事事5 小时前
如何让AI写代码越写越像你
前端·后端
Allen正心正念20255 小时前
前端——Node.js&npm,学点前端的东西
前端·npm·node.js
西瓜有点饿5 小时前
前端基础知识之---Content-Type有哪些格式
前端