React性能优化

概念

性能优化是指通过减少不必要的渲染或计算来提高应用的性能。React 提供了 React.memouseCallbackuseMemo 等工具来优化性能。

用法

  • React.memo:缓存函数组件,避免在 Props 没有变化时重新渲染。
  • useCallback:缓存回调函数,避免在每次渲染时重新创建。
  • useMemo:缓存计算结果,避免在依赖项没有变化时重新计算。

使用场景

  • React.memo:当父组件重新渲染时,子组件不需要重新渲染。
  • useCallback:当回调函数作为 Props 传递给子组件时。
  • useMemo:当计算结果依赖复杂逻辑或大量数据时。

代码示例

javascript 复制代码
// 1. 使用 React.memo 缓存组件
const ExpensiveComponent = React.memo(function({ value }) {
  console.log('ExpensiveComponent rendered');
  return <div>Value: {value}</div>;
});

function ParentComponent() {
  const [count, setCount] = React.useState(0);
  const [value, setValue] = React.useState(10);

  // 2. 使用 useCallback 缓存回调函数
  const increment = React.useCallback(() => {
    setCount(prev => prev + 1);
  }, []);

  // 3. 使用 useMemo 缓存计算结果
  const doubledValue = React.useMemo(() => {
    console.log('Calculating doubled value');
    return value * 2;
  }, [value]);

  return (
    <div>
      <button onClick={increment}>Increment Count: {count}</button>
      <button onClick={() => setValue(prev => prev + 5)}>Change Value: {value}</button>
      <div>Doubled Value: {doubledValue}</div>
      <ExpensiveComponent value={doubledValue} />
    </div>
  );
}

代码解析

  • React.memoExpensiveComponent 只会在 value 变化时重新渲染。
  • useCallbackincrement 函数在组件渲染时不会重新创建。
  • useMemodoubledValue 只会在 value 变化时重新计算。
相关推荐
摆烂大大王1 小时前
玩转 OpenClaw:用 TaskFlow + Heartbeat 打造自动化工作流
前端·人工智能·自动化
zhangxingchao1 小时前
AI 大模型核心六:量化、Workflow 与 Agent、多轮 RAG
前端·人工智能·后端
梦想的颜色2 小时前
TypeScript 完全指南(上):从零开始掌握类型系统
前端·typescript
之歆2 小时前
Day01_ES6+ 专业指南:从基础到实战的现代JavaScript开发(下)
前端·javascript·es6
花椒技术2 小时前
复杂直播业务做 RN 跨端,我们最后保留了哪些 Native 边界
react native·react.js·harmonyos
lichenyang4532 小时前
鸿蒙 MVVM 实战:从 Demo 到工程化,聊聊登录、状态管理与埋点系统设计
前端
IT_陈寒2 小时前
Vite打包时遇到的坑,原来问题出在这里
前端·人工智能·后端
kyriewen3 小时前
AI生成代码快如闪电,但我修了三个小时——它到底帮了谁?
前端·javascript·ai编程
ayqy贾杰3 小时前
基层管理的三板斧,在AI时代行不通了
前端·后端·团队管理
Apifox3 小时前
Apifox 5 月更新|Postman 导入优化、Runner 支持非 root 运行、请求代码自动带鉴权
前端·后端·安全