VercelReact性能优化最佳实践Skill vercel-react-best-practices

本技能提供由Vercel工程团队维护的React和Next.js应用性能优化指南,涵盖57条规则,分为8个优先级类别,帮助开发者在编写、审查、重构代码时优化性能,关键词包括React、Next.js、前端开发、性能优化、Vercel、数据获取、包大小优化、渲染优化、JavaScript优化,适用于提升网站速度和用户体验。

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

名称: vercel-react-best-practices 描述: 由Vercel工程团队维护的React和Next.js性能优化指南。该技能应在编写、审查或重构React/Next.js代码时使用,以确保最佳性能模式。触发涉及React组件、Next.js页面、数据获取、包优化或性能改进的任务。 许可证: MIT 元数据: 作者: vercel 版本: “1.0.0” 内部: true

Vercel React 最佳实践

React和Next.js应用程序的综合性能优化指南,由Vercel维护。包含8个类别中的57条规则,按影响优先级排序,以指导自动化重构和代码生成。

何时应用

在以下情况下参考这些指南:

  • 编写新的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路由中提前开始承诺,稍后等待
  • async-suspense-boundaries - 使用Suspense流式传输内容

2. 包大小优化(关键)

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

3. 服务器端性能(高)

  • server-auth-actions - 像API路由一样验证服务器操作
  • server-cache-react - 使用React.cache()进行请求级去重
  • server-cache-lru - 使用LRU缓存进行跨请求缓存
  • server-dedup-props - 避免RSC属性中的重复序列化
  • server-serialization - 最小化传递给客户端组件的数据
  • server-parallel-fetching - 重构组件以并行化获取
  • server-after-nonblocking - 使用after()进行非阻塞操作

4. 客户端数据获取(中等-高)

  • client-swr-dedup - 使用SWR进行自动请求去重
  • client-event-listeners - 去重全局事件监听器
  • client-passive-event-listeners - 使用被动监听器处理滚动
  • client-localstorage-schema - 版本化和最小化localStorage数据

5. 重新渲染优化(中等)

  • rerender-defer-reads - 不要订阅仅在回调中使用的状态
  • rerender-memo - 将昂贵工作提取到记忆化组件中
  • rerender-memo-with-default-value - 提升默认非原始属性
  • rerender-dependencies - 在effect中使用原始依赖项
  • rerender-derived-state - 订阅派生布尔值,而非原始值
  • rerender-derived-state-no-effect - 在渲染期间派生状态,而非在effect中
  • rerender-functional-setstate - 使用功能setState获取稳定回调
  • rerender-lazy-state-init - 将函数传递给useState以延迟初始化昂贵值
  • rerender-simple-expression-in-memo - 避免对简单原始值使用memo
  • rerender-move-effect-to-event - 将交互逻辑放在事件处理程序中
  • rerender-transitions - 使用startTransition处理非紧急更新
  • rerender-use-ref-transient-values - 使用ref处理频繁变化的瞬态值

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-hydration-suppress-warning - 抑制预期的不匹配警告
  • rendering-activity - 使用Activity组件进行显示/隐藏
  • rendering-conditional-render - 使用三元运算符,而非&&处理条件渲染
  • rendering-usetransition-loading - 优先使用useTransition处理加载状态

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 - 使用循环计算最小/最大值,而非排序
  • js-set-map-lookups - 使用Set/Map进行O(1)查找
  • js-tosorted-immutable - 使用toSorted()实现不变性

8. 高级模式(低)

  • advanced-event-handler-refs - 在ref中存储事件处理程序
  • advanced-init-once - 每个应用加载时初始化一次
  • advanced-use-latest - 使用useLatest获取稳定回调refs

如何使用

阅读单独的规则文件获取详细解释和代码示例:

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

每个规则文件包含:

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

完整编译文档

要获取包含所有扩展规则的完整指南:AGENTS.md