🚀 快速安装

复制以下命令并运行,立即安装此 Skill:

npx skills add https://skills.sh/vercel-labs/agent-skills/vercel-react-best-practices

💡 提示:需要 Node.js 和 NPM

Vercel React 最佳实践

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

何时应用

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

  • 编写新的 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 路由中尽早启动 Promise,延迟等待
  • async-suspense-boundaries – 使用 Suspense 流式传输内容

2. 打包大小优化 (关键)

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

3. 服务器端性能 (高)

  • server-auth-actions – 像 API 路由一样对服务器操作进行身份验证
  • server-cache-react – 使用 React.cache() 进行单次请求的去重
  • server-cache-lru – 使用 LRU 缓存进行跨请求缓存
  • server-dedup-props – 避免在 RSC props 中重复序列化
  • server-hoist-static-io – 将静态 I/O(字体、Logo)提升到模块级别
  • 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 – 将昂贵计算提取到 memo 化的组件中
  • rerender-memo-with-default-value – 提升默认的非原始类型 props
  • 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 – 抑制预期的 hydration 不匹配警告
  • 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 获取稳定的回调引用

如何使用

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

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

每个规则文件包含:

  • 关于该规则重要性的简要说明
  • 错误的代码示例及解释
  • 正确的代码示例及解释
  • 附加上下文和参考资料

完整汇编文档

如需包含所有规则扩展的完整指南:AGENTS.md

📄 原始文档

完整文档(英文):

/vercel-labs/agent-skills/vercel-react-best-practices

💡 提示:点击上方链接查看 skills.sh 原始英文文档,方便对照翻译。

声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。