首页龙虾技能列表 › Vercel React Best Practices — Vercel React 最佳实践 — React 和 Next.js 性能优化指南

Vercel React Best Practices — Vercel React 最佳实践 — React 和 Next.js 性能优化指南

v0.1.0

Vercel 工程团队提供的 React 和 Next.js 性能优化指南,包含 62 个优化规则,涵盖数据获取、包大小、服务器/客户端渲染、重新渲染等方面。适用于编写、审查或重构 React/Next.js 代码以确保最佳性能实践。

4· 1,200·2 当前·4 累计
by @analsharqy (Quantyra)·MIT-0
下载技能包
License
MIT-0
最后更新
2026/3/17
安全扫描
VirusTotal
无害
查看报告
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(正常)。本技能可以自主调用(平台默认),这对于技能来说是预期的;没有指示它请求永久提升的存在或修改其他技能。
安全有层次,运行前请审查代码。

License

MIT-0

可自由使用、修改和再分发,无需署名。

运行时依赖

无特殊依赖

版本

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-
7JavaScript 性能中低js-
8高级模式advanced-

快速参考

1. 消除瀑布流(关键)

  • 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 - 直接导入,避免 barrel 文件
  • 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 - 在 effects 中使用原始依赖
  • rerender-derived-state - 订阅派生的布尔值,而非原始值
  • rerender-derived-state-no-effect - 在渲染期间派生状态,而非 effects
  • 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 - 对频繁的瞬态值使用 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 - 抑制预期的 mismatches
  • 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 - 通过类或 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 - 使用循环而非排序求 min/max
  • js-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 技能定制 / 插件定制 / 私有工作流定制

免费技能或插件可能存在安全风险,如需更匹配、更安全的方案,建议联系付费定制

了解定制服务