vercel-react-best-practices vercel-react-best-practices

Vercel React 最佳实践是一套全面的 React 和 Next.js 性能优化指南,由 Vercel 维护。这套指南包含 45 条规则,覆盖 8 个类别,旨在指导开发者在编写、审查或重构 React/Next.js 代码时,遵循最佳性能模式。关键词包括:性能优化、React 组件、Next.js 页面、数据获取、捆绑包优化、性能改进。

前端开发 0 次安装 0 次浏览 更新于 3/5/2026

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-all 处理部分依赖
  • async-api-routes - 在 API 路由中尽早启动承诺,晚些时候 await
  • async-suspense-boundaries - 使用 Suspense 流式传输内容

2. 捆绑包大小优化(严重)

  • bundle-barrel-imports - 直接导入,避免桶文件
  • bundle-dynamic-imports - 使用 next/dynamic 处理重组件
  • bundle-defer-third-party - 在水合后加载分析/日志
  • bundle-conditional - 仅在功能激活时加载模块
  • bundle-preload - 在悬停/聚焦时预加载,以感知速度

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 - 不要订阅仅在回调中使用的 state
  • rerender-memo - 将昂贵的工作提取到 memoized 组件中
  • rerender-dependencies - 在效果中使用原始依赖
  • rerender-derived-state - 订阅派生布尔值,而不是原始值
  • rerender-functional-setstate - 使用函数 setState 进行稳定的回调
  • rerender-lazy-state-init - 为昂贵的值向 useState 传递函数
  • rerender-transitions - 使用 startTransition 进行非紧急更新

6. 渲染性能(中)

  • rendering-animate-svg-wrapper - 动画 div 包装器,而不是 SVG 元素
  • rendering-content-visibility - 使用 content-visibility 处理长列表
  • rendering-hoist-jsx - 将静态 JSX 提取到组件外部
  • rendering-svg-precision - 降低 SVG 坐标精度
  • rendering-hydration-no-flicker - 使用内联脚本处理客户端仅数据
  • rendering-activity - 使用 Activity 组件显示/隐藏
  • rendering-conditional-render - 使用三元运算符,而不是 && 进行条件渲染

7. JavaScript 性能(低-中)

  • js-batch-dom-css - 通过类或 cssText 批量 CSS 更改
  • js-index-maps - 为重复查找构建 Map
  • js-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 - 使用循环进行 min/max,而不是排序
  • js-set-map-lookups - 使用 Set/Map 进行 O(1) 查找
  • js-tosorted-immutable - 使用 toSorted() 处理不变性

8. 高级模式(低)

  • advanced-event-handler-refs - 在 refs 中存储事件处理程序
  • advanced-use-latest - useLatest 用于稳定的回调 refs

如何使用

阅读各个规则文件以获取详细说明和代码示例:

rules/async-parallel.md
rules/bundle-barrel-imports.md
rules/_sections.md

每个规则文件包含:

  • 简要解释为什么重要
  • 不正确的代码示例及解释
  • 正确的代码示例及解释
  • 额外的上下文和参考

完整编译文档

对于所有规则展开的完整指南:AGENTS.md