安装方式
命令行安装
在项目根目录执行以下命令,完成 Skill 安装。
npx bzskills add vercel-labs/agent-skills --skill vercel-react-best-practices React 和 Next.js 性能优化指南(来自 Vercel 工程团队)。此技能应在编写、审查或重构 React/Next.js 代码时使用,以确保遵循最佳性能模式。可触发于涉及 React 组件、Next.js 页面、数据获取、打包优化或性能改进的任务。
383.1k
下载量
命令行安装
在项目根目录执行以下命令,完成 Skill 安装。
npx bzskills add vercel-labs/agent-skills --skill vercel-react-best-practices name: vercel-react-best-practices
description: React 和 Next.js 性能优化指南(来自 Vercel 工程团队)。此技能应在编写、审查或重构 React/Next.js 代码时使用,以确保遵循最佳性能模式。可触发于涉及 React 组件、Next.js 页面、数据获取、打包优化或性能改进的任务。
license: MIT
metadata:
author: vercel
version: "1.0.0"由 Vercel 维护的 React 和 Next.js 应用综合性能优化指南。包含 8 个类别共 70 条规则,按影响程度排序,指导自动化重构和代码生成。
在以下场景参考这些指南:
| 优先级 | 类别 | 影响 | 前缀 |
|---|---|---|---|
| 1 | 消除瀑布请求 | 关键 | async- |
| 2 | 打包体积优化 | 关键 | bundle- |
| 3 | 服务器端性能 | 高 | server- |
| 4 | 客户端数据获取 | 中高 | client- |
| 5 | 重渲染优化 | 中 | rerender- |
| 6 | 渲染性能 | 中 | rendering- |
| 7 | JavaScript 性能 | 低中 | js- |
| 8 | 高级模式 | 低 | advanced- |
async-cheap-condition-before-await - 在 await 标记或远程值之前检查廉价的同步条件async-defer-await - 将 await 移至实际使用的分支内async-parallel - 对独立操作使用 Promise.all()async-dependencies - 对部分依赖使用 better-allasync-api-routes - 在 API 路由中尽早启动 Promise,延迟 awaitasync-suspense-boundaries - 使用 Suspense 实现内容流式传输bundle-barrel-imports - 直接导入,避免桶文件bundle-analyzable-paths - 优先使用静态可分析的导入和文件系统路径,避免大包和追踪bundle-dynamic-imports - 对重型组件使用 next/dynamicbundle-defer-third-party - 在 hydration 后加载分析/日志bundle-conditional - 仅在功能激活时加载模块bundle-preload - 在悬停/聚焦时预加载以提高感知速度server-auth-actions - 像 API 路由一样对服务器操作进行身份验证server-cache-react - 使用 React.cache() 实现每请求去重server-cache-lru - 使用 LRU 缓存实现跨请求缓存server-dedup-props - 避免在 RSC props 中重复序列化server-hoist-static-io - 将静态 I/O(字体、标识)提升到模块级别server-no-shared-module-state - 避免在 RSC/SSR 中使用模块级别的可变请求状态server-serialization - 最小化传递给客户端组件的数据server-parallel-fetching - 重组组件以并行化获取server-parallel-nested-fetching - 在 Promise.all 中每个项目链式嵌套获取server-after-nonblocking - 对非阻塞操作使用 after()client-swr-dedup - 使用 SWR 实现自动请求去重client-event-listeners - 去重全局事件监听器client-passive-event-listeners - 对滚动使用 passive 监听器client-localstorage-schema - 对 localStorage 数据进行版本化和最小化rerender-defer-reads - 不要订阅仅在回调中使用的状态rerender-memo - 将昂贵的工作提取到记忆化组件中rerender-memo-with-default-value - 提升默认的非原始 propsrerender-dependencies - 在 effect 中使用原始依赖rerender-derived-state - 订阅派生布尔值,而不是原始值rerender-derived-state-no-effect - 在渲染期间派生状态,而不是 effectrerender-functional-setstate - 使用函数式 setState 以获得稳定的回调rerender-lazy-state-init - 为昂贵值向 useState 传递函数rerender-simple-expression-in-memo - 避免对简单原始值使用 memorerender-split-combined-hooks - 拆分具有独立依赖的 hooksrerender-move-effect-to-event - 将交互逻辑放入事件处理程序rerender-transitions - 对非紧急更新使用 startTransitionrerender-use-deferred-value - 延迟昂贵的渲染以保持输入响应rerender-use-ref-transient-values - 对瞬态频繁值使用 refsrerender-no-inline-components - 不要在组件内部定义组件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 - 抑制预期的不匹配rendering-activity - 使用 Activity 组件实现显示/隐藏rendering-conditional-render - 使用三元运算符,而不是 && 进行条件渲染rendering-usetransition-loading - 对加载状态优先使用 useTransitionrendering-resource-hints - 使用 React DOM 资源提示进行预加载rendering-script-defer-async - 在 script 标签上使用 defer 或 asyncjs-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 - 使用循环查找最小/最大值,而不是 sortjs-set-map-lookups - 使用 Set/Map 实现 O(1) 查找js-tosorted-immutable - 使用 toSorted() 实现不可变性js-flatmap-filter - 使用 flatMap 一次完成映射和过滤js-request-idle-callback - 将非关键工作延迟到浏览器空闲时间advanced-effect-event-deps - 不要将 useEffectEvent 结果放入 effect 依赖中advanced-event-handler-refs - 将事件处理程序存储在 refs 中advanced-init-once - 每次应用加载时初始化一次advanced-use-latest - 使用 useLatest 获取稳定的回调引用阅读各规则文件以获取详细解释和代码示例:
rules/async-parallel.md
rules/bundle-barrel-imports.md
每个规则文件包含:
获取包含所有规则的完整指南:AGENTS.md