
关于
Vercel 维护的 React 和 Next.js 应用全面性能优化指南。在编写 React 组件、优化渲染性能或构建 Next.js 应用时使用。
name: react-best-practices description: "React 和 Next.js 应用的综合性能优化指南,由 Vercel 维护。适用于编写新的 React 组件或 Next.js 页面、实现数据获取(客户端或服务端)、或审查代码性能问题时使用。" risk: safe source: community date_added: "2026-02-27"
Vercel React 最佳实践
React 和 Next.js 应用的综合性能优化指南,由 Vercel 维护。包含 8 个类别共 45 条规则,按影响程度排列优先级,用于指导自动化重构和代码生成。
使用场景
在以下情况下参考这些指南:
- 编写新的 React 组件或 Next.js 页面
- 实现数据获取(客户端或服务端)
- 审查代码性能问题
- 重构现有 React/Next.js 代码
- 优化包体积或加载时间
规则类别(按优先级排列)
| 优先级 | 类别 | 影响程度 | 前缀 |
|--------|------|----------|------|
| 1 | 消除瀑布流请求 | 关键 | async- |
| 2 | 包体积优化 | 关键 | bundle- |
| 3 | 服务端性能 | 高 | server- |
| 4 | 客户端数据获取 | 中高 | client- |
| 5 | 重渲染优化 | 中 | rerender- |
| 6 | 渲染性能 | 中 | rendering- |
| 7 | JavaScript 性能 | 低中 | js- |
| 8 | 高级模式 | 低 | advanced- |
快速参考
1. 消除瀑布流请求(关键)
async-defer-await- 将 await 移到实际使用的分支中async-parallel- 对独立操作使用 Promise.all()async-dependencies- 对部分依赖使用 better-allasync-api-routes- 在 API 路由中尽早启动 promise,延迟 awaitasync-suspense-boundaries- 使用 Suspense 流式传输内容
2. 包体积优化(关键)
bundle-barrel-imports- 直接导入,避免桶文件bundle-dynamic-imports- 对重型组件使用 next/dynamicbundle-defer-third-party- 在 hydration 后加载分析/日志工具bundle-conditional- 仅在功能激活时加载模块bundle-preload- 在 hover/focus 时预加载以提升感知速度
3. 服务端性能(高)
server-cache-react- 使用 React.cache() 进行请求级去重server-cache-lru- 使用 LRU 缓存进行跨请求缓存server-serialization- 最小化传递给客户端组件的数据server-parallel-fetching- 重构组件以并行化数据获取server-after-nonblocking- 使用 after() 进行非阻塞操作
4. 客户端数据获取(中高)
client-swr-dedup- 使用 SWR 自动去重请求client-event-listeners- 去重全局事件监听器
5. 重渲染优化(中)
rerender-defer-reads- 不要订阅仅在回调中使用的状态rerender-memo- 将昂贵计算提取到 memo 化组件中rerender-dependencies- 在 effects 中使用原始类型依赖rerender-derived-state- 订阅派生布尔值,而非原始值rerender-functional-setstate- 使用函数式 setState 获得稳定回调rerender-lazy-state-init- 对昂贵初始值传递函数给 useStatererender-transitions- 对非紧急更新使用 startTransition
6. 渲染性能(中)
rendering-animate-svg-wrapper- 动画化 div 包装器,而非 SVG 元素rendering-content-visibility- 对长列表使用 content-visibilityrendering-hoist-jsx- 将静态 JSX 提取到组件外部rendering-svg-precision- 降低 SVG 坐标精度rendering-hydration-no-flicker- 使用内联脚本处理仅客户端数据rendering-activity- 使用 Activity 组件控制显示/隐藏rendering-conditional-render- 使用三元运算符,而非 && 进行条件渲染
7. JavaScript 性能(低中)
js-batch-dom-css- 通过 class 或 cssText 批量修改 CSSjs-index-maps- 为重复查找构建 Mapjs-cache-property-access- 在循环中缓存对象属性js-cache-function-results- 在模块级 Map 中缓存函数结果js-cache-storage- 缓存 localStorage/sessionStorage 读取js-combine-iterations- 将多个 filter/map 合并为一个循环js-length-check-first- 在昂贵比较前先检查数组长度js-early-exit- 函数尽早返回js-hoist-regexp- 将 RegExp 创建提升到循环外js-min-max-loop- 使用循环求最值而非 sortjs-set-map-lookups- 使用 Set/Map 实现 O(1) 查找js-tosorted-immutable- 使用 toSorted() 保持不可变性
8. 高级模式(低)
advanced-event-handler-refs- 将事件处理器存储在 refs 中advanced-use-latest- 使用 useLatest 获得稳定的回调引用
使用方法
阅读各规则文件获取详细说明和代码示例:
rules/async-parallel.md
rules/bundle-barrel-imports.md
rules/_sections.md
每个规则文件包含:
- 简要说明
兼容工具
Claude CodeCursor
标签
前端开发