名称: vercel-react-best-practices 描述: Vercel工程提供的React和Next.js性能优化指南。当编写、审查或重构React/Next.js代码时,应使用此技能以确保最佳性能模式。触发涉及React组件、Next.js页面、数据获取、包优化或性能改进的任务。 许可证: MIT 元数据: 作者: vercel 版本: “1.0.0” 领域: 前端 触发词: React, React性能, Next.js优化, 包大小, 重新渲染, 数据获取, Suspense, 服务器组件, 记忆化, 代码分割, 瀑布流 角色: 专家 范围: 实现 输出格式: 代码 相关技能: react专家, nextjs开发者, vercel组合模式
Vercel React 最佳实践
Vercel维护的React和Next.js应用程序性能优化全面指南。包含57条规则,分为8个类别,按影响优先级排列,以指导自动化重构和代码生成。
何时应用
在以下情况下参考这些指南:
- 编写新的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路由中早期启动promises,晚期awaitasync-suspense-boundaries- 使用Suspense流式传输内容
2. 包大小优化(关键)
bundle-barrel-imports- 直接导入,避免桶文件bundle-dynamic-imports- 对重型组件使用next/dynamicbundle-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 props中的重复序列化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- 提升默认非原始propsrerender-dependencies- 在effects中使用原始依赖项rerender-derived-state- 订阅派生布尔值,而不是原始值rerender-derived-state-no-effect- 在渲染期间派生状态,而非effectsrerender-functional-setstate- 对稳定回调使用功能性setStatererender-lazy-state-init- 对昂贵值向useState传递函数rerender-simple-expression-in-memo- 对简单原始值避免memorerender-move-effect-to-event- 将交互逻辑放在事件处理程序中rerender-transitions- 对非紧急更新使用startTransitionrerender-use-ref-transient-values- 对瞬态频繁值使用refs
6. 渲染性能(中)
rendering-animate-svg-wrapper- 动画div包装器,而非SVG元素rendering-content-visibility- 对长列表使用content-visibilityrendering-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- 为重复查找构建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- 使用循环求最小/最大值,而非排序js-set-map-lookups- 使用Set/Map进行O(1)查找js-tosorted-immutable- 对不变性使用toSorted()
8. 高级模式(低)
advanced-event-handler-refs- 在refs中存储事件处理程序advanced-init-once- 每次应用加载初始化一次应用advanced-use-latest- 对稳定回调refs使用useLatest
如何使用
阅读单个规则文件以获取详细解释和代码示例:
rules/async-parallel.md
rules/bundle-barrel-imports.md
每个规则文件包含:
- 简要解释为何重要
- 错误代码示例及解释
- 正确代码示例及解释
- 额外上下文和引用
完整编译文档
对于包含所有规则扩展的完整指南:AGENTS.md