Vercel React Best Practices — Vercel React 最佳实践 — React 和 Next.js 性能优化指南
v0.1.0Vercel 工程团队提供的 React 和 Next.js 性能优化指南,包含 62 个优化规则,涵盖数据获取、包大小、服务器/客户端渲染、重新渲染等方面。适用于编写、审查或重构 React/Next.js 代码以确保最佳性能实践。
4· 1,200·2 当前·4 累计
安全扫描
OpenClaw
安全
medium confidence本技能为一份仅包含指令的 React/Next.js 性能规则仓库,匹配其声明目的,不请求凭据或安装,但其来源未经验证,启用自动重构前请谨慎。
评估建议
本技能是一份大型、仅包含指令的 React/Next.js 性能优化指南,内部一致。启用前:1) 如果需要官方 Vercel背书,请验证发布者/来源。2) 如果允许自动重构,请要求代码审查和运行测试套件。3) 应用自动修复前保留备份。4) 如需更严格控制,只手动调用本技能,不授予额外凭据。确认来源(官方 Vercel 仓库或可信镜像)后,信心度将提高。...详细分析 ▾
✓ 用途与能力
名称/描述(Vercel React 最佳实践)与提供的文件一致:一份针对 React 和 Next.js 性能的大型、基于规则的指南。本技能不请求二进制文件、环境变量或安装,这对于一份仅包含文档/指令的技能是合理的。
ℹ 指令范围
SKILL.md 和 AGENTS.md 为编写/审查/重构代码提供指南,明确针对代理/LLM 进行优化。指令不请求无关文件、凭据或外部端点。注意:由于指南旨在用于自动重构,使用本技能的代理可能会修改代码——用户应计划审查差异并运行测试。
✓ 安装机制
无安装规格和代码执行文件 — 本技能仅包含指令(Markdown 文件)。从安装角度看,这是低风险的(没有下载或由安装程序写入的内容)。
✓ 凭证需求
本技能不声明环境变量、凭据或配置路径,其内容也不引用秘密。没有请求不当的凭据或环境访问。
✓ 持久化与权限
标志:always 为 false,user-invocable 为 true(正常)。本技能可以自主调用(平台默认),这对于技能来说是预期的;没有指示它请求永久提升的存在或修改其他技能。
安全有层次,运行前请审查代码。
运行时依赖
无特殊依赖
版本
latestv0.1.02026/3/17
Vercel React 最佳实践技能的初始发布。- 提供 62 个针对 React 和 Next.js 应用的优化规则,按优先级排序。- 覆盖数据获取、包大小、服务器/客户端渲染、重新渲染等性能类别。- 包含快速参考列表和规则标识符以便快速查阅。- 设计用于代码编写、审查或重构阶段,以确保最佳性能实践。- 提供指向完整规则解释和编译指南的参考。
● 无害
安装命令 点击复制
官方npx clawhub@latest install react-best-practices-2
镜像加速npx clawhub@latest install react-best-practices-2 --registry https://cn.clawhub-mirror.com
技能文档
由 Vercel 维护的 React 和 Next.js 应用综合性能优化指南。包含 8 个类别共 62 条规则,按影响程度排序,指导自动化重构和代码生成。
何时应用
在以下情况下参考这些指南:
- 编写新的 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,延迟 awaitasync-suspense-boundaries- 使用 Suspense 流式传输内容
2. 捆绑包大小优化(关键)
bundle-barrel-imports- 直接导入,避免 barrel 文件bundle-dynamic-imports- 对重型组件使用 next/dynamicbundle-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- 提升默认非原始 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- 对频繁的瞬态值使用 refsrerender-no-inline-components- 不要在组件内部定义组件
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- 抑制预期的 mismatchesrendering-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- 通过类或 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- 使用循环而非排序求 min/maxjs-set-map-lookups- 使用 Set/Map 进行 O(1) 查找js-tosorted-immutable- 使用 toSorted() 实现不可变性js-flatmap-filter- 使用 flatMap 在一次传递中 map 和 filter
8. 高级模式(低)
advanced-event-handler-refs- 在 refs 中存储事件处理器advanced-init-once- 每次应用加载时初始化一次advanced-use-latest- 使用 useLatest 获取稳定的回调 refs
使用方法
阅读各规则文件以获取详细说明和代码示例:
rules/async-parallel.md
rules/bundle-barrel-imports.md
每个规则文件包含:
- 为何重要的简要说明
- 带说明的错误代码示例
- 带说明的正确代码示例
- 其他上下文和参考
完整编译文档
包含所有规则扩展的完整指南见:AGENTS.md
数据来源:ClawHub ↗ · 中文优化:龙虾技能库
OpenClaw 技能定制 / 插件定制 / 私有工作流定制
免费技能或插件可能存在安全风险,如需更匹配、更安全的方案,建议联系付费定制