返回全部 Skills

vercel-react-best-practices

开发工具

来自 Vercel Engineering 的 React 和 Next.js 性能优化指南。此技能应用于编写、审查或重构 React/Next.js 代码,以确保最佳性能模式。触发的任务涉及 React 组件、Next.js 页面、数据获取、包优化或性能改进。

383.2k

下载量

AI SkillHub 能力展示图

安装方式

命令行安装

在项目根目录执行以下命令,完成 Skill 安装。

npx bzskills add vercel-labs/agent-skills --skill vercel-react-best-practices

skill.md

name: vercel-react-best-practices
description: 来自 Vercel Engineering 的 React 和 Next.js 性能优化指南。此技能应用于编写、审查或重构 React/Next.js 代码,以确保最佳性能模式。触发的任务涉及 React 组件、Next.js 页面、数据获取、包优化或性能改进。
license: MIT
metadata:
    author: vercel
    version: "1.0.0"

Vercel React 最佳实践

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

适用场景

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

  • 编写新的 React 组件或 Next.js 页面
  • 实现数据获取(客户端或服务端)
  • 审查代码中的性能问题
  • 重构现有的 React/Next.js 代码
  • 优化包体积或加载时间

按优先级分类的规则类别

优先级类别影响前缀
1消除瀑布流关键async-
2包体积优化关键bundle-
3服务端性能server-
4客户端数据获取中高client-
5重渲染优化rerender-
6渲染性能rendering-
7JavaScript 性能低中js-
8高级模式advanced-

快速参考

1. 消除瀑布流(关键)

  • async-cheap-condition-before-await - 在等待标记或远程值之前,先检查廉价的同步条件
  • async-defer-await - 将 await 移动到实际使用它的分支中
  • async-parallel - 对独立操作使用 Promise.all()
  • async-dependencies - 对部分依赖使用 better-all
  • async-api-routes - 在 API 路由中尽早发起 promise,延迟 await
  • async-suspense-boundaries - 使用 Suspense 流式传输内容

2. 包体积优化(关键)

  • bundle-barrel-imports - 直接导入,避免使用桶文件
  • bundle-analyzable-paths - 优先使用可静态分析的导入和文件系统路径,避免产生宽泛的包和追踪
  • bundle-dynamic-imports - 对重型组件使用 next/dynamic
  • bundle-defer-third-party - 在 hydration 后加载分析/日志记录
  • bundle-conditional - 仅在功能激活时加载模块
  • bundle-preload - 在悬停/聚焦时预加载,提升感知速度

3. 服务端性能(高)

  • server-auth-actions - 像 API 路由一样对 Server Actions 进行身份验证
  • server-cache-react - 使用 React.cache() 实现每个请求的去重
  • server-cache-lru - 使用 LRU 缓存实现跨请求缓存
  • server-dedup-props - 避免 RSC props 中的重复序列化
  • server-hoist-static-io - 将静态 I/O(字体、Logo)提升到模块级别
  • server-no-shared-module-state - 在 RSC/SSR 中避免模块级别的可变请求状态
  • server-serialization - 最小化传递给客户端组件的数据
  • server-parallel-fetching - 重构组件以并行执行数据获取
  • server-parallel-nested-fetching - 在 Promise.all 中对每个项目串联嵌套的数据获取
  • 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-split-combined-hooks - 拆分具有独立依赖的 hooks
  • rerender-move-effect-to-event - 将交互逻辑放入事件处理函数中
  • rerender-transitions - 对非紧急更新使用 startTransition
  • rerender-use-deferred-value - 延迟开销大的渲染,保持输入响应性
  • rerender-use-ref-transient-values - 使用 refs 存储瞬态高频变化的值
  • rerender-no-inline-components - 不要在组件内部定义组件

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 处理加载状态
  • rendering-resource-hints - 使用 React DOM 资源提示进行预加载
  • rendering-script-defer-async - 在 script 标签上使用 defer 或 async

7. JavaScript 性能(低中)

  • js-batch-dom-css - 通过 class 或 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() 保持不可变性
  • js-flatmap-filter - 使用 flatMap 一次完成映射和过滤
  • js-request-idle-callback - 将非关键工作推迟到浏览器空闲时执行

8. 高级模式(低)

  • advanced-effect-event-deps - 不要将 useEffectEvent 的结果放入 effect 依赖中
  • advanced-event-handler-refs - 将事件处理函数存储在 refs 中
  • advanced-init-once - 每次应用加载时只初始化一次应用
  • advanced-use-latest - 使用 useLatest 获取稳定的回调 ref

使用方法

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

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

每个规则文件包含:

  • 为什么重要的简要说明
  • 错误代码示例及解释
  • 正确代码示例及解释
  • 额外上下文和参考资料

完整编译文档

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