名称: vercel-react-best-practices
描述: 来自 Vercel 工程团队的 React 与 Next.js 性能优化指南。在编写、评审或重构 React/Next.js 代码时,应使用此技能以确保遵循最佳性能模式。当任务涉及 React 组件、Next.js 页面、数据获取、打包优化或性能改进时触发。
许可证: MIT
元数据:
author: vercel
version: "1.0.0"
由 Vercel 维护的 React 与 Next.js 应用性能优化综合指南。包含 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- |
async-defer-await - 将 await 移至实际使用的分支中async-parallel - 对独立操作使用 Promise.all()async-dependencies - 对部分依赖使用 better-allasync-api-routes - 在 API 路由中尽早启动 Promise,稍后 awaitasync-suspense-boundaries - 使用 Suspense 流式传输内容bundle-barrel-imports - 直接导入,避免使用 Barrel 文件bundle-dynamic-imports - 对重型组件使用 next/dynamicbundle-defer-third-party - 在 hydration 后加载分析/日志工具bundle-conditional - 仅在功能激活时加载模块bundle-preload - 在悬停/聚焦时预加载以提升感知速度server-cache-react - 使用 React.cache() 实现请求级去重server-cache-lru - 使用 LRU 缓存实现跨请求缓存server-serialization - 最小化传递给客户端组件的数据server-parallel-fetching - 重构组件以实现并行获取server-after-nonblocking - 使用 after() 处理非阻塞操作client-swr-dedup - 使用 SWR 实现自动请求去重client-event-listeners - 对全局事件监听器进行去重rerender-defer-reads - 不要订阅仅在回调中使用的状态rerender-memo - 将昂贵计算提取到 memoized 组件中rerender-dependencies - 在 effect 中使用原始值依赖项rerender-derived-state - 订阅派生的布尔值,而非原始值rerender-functional-setstate - 使用函数式 setState 以获得稳定的回调rerender-lazy-state-init - 向 useState 传递函数以惰性初始化昂贵值rerender-transitions - 对非紧急更新使用 startTransitionrendering-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 - 使用三元运算符而非 && 进行条件渲染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 - 使用循环而非 sort 求最小/最大值js-set-map-lookups - 使用 Set/Map 实现 O(1) 查找js-tosorted-immutable - 使用 toSorted() 实现不可变性advanced-event-handler-refs - 将事件处理器存储在 ref 中advanced-use-latest - 使用 useLatest 获得稳定的回调引用阅读单个规则文件以获取详细解释和代码示例:
rules/async-parallel.md
rules/bundle-barrel-imports.md
rules/_sections.md
每个规则文件包含:
- 简要说明其重要性
- 错误代码示例及解释
- 正确代码示例及解释
- 额外上下文和参考资料
获取包含所有规则详解的完整指南:AGENTS.md