vercel-react-best-practices
3
总安装量
1
周安装量
#57357
全站排名
安装命令
npx skills add https://github.com/lingxling/awesome-skills-cn --skill vercel-react-best-practices
Agent 安装分布
mcpjam
1
claude-code
1
junie
1
windsurf
1
zencoder
1
crush
1
Skill 文档
Vercel React æä½³å®è·µ
ç±Vercelç»´æ¤çReactåNext.jsåºç¨ç¨åºç»¼åæ§è½ä¼åæåãå å«8个类å«ä¸ç57æ¡è§åï¼æå½±åä¼å 级æåºï¼ä»¥æå¯¼èªå¨åéæå代ç çæã
使¶åºç¨
å¨ä»¥ä¸æ åµä¸åèè¿äºæåï¼
- ç¼åæ°ç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-allasync-api-routes– å¨APIè·¯ç±ä¸å°½æ©å¯å¨promiseï¼å»¶è¿awaitasync-suspense-boundaries– 使ç¨Suspenseæµå¼ä¼ è¾å 容
2. å 大å°ä¼åï¼å ³é®ï¼
bundle-barrel-imports– ç´æ¥å¯¼å ¥ï¼é¿å æ¡¶æä»¶bundle-dynamic-imports– 对éåç»ä»¶ä½¿ç¨next/dynamicbundle-defer-third-party– 卿°´ååå è½½åæ/æ¥å¿bundle-conditional– ä» å¨æ¿æ´»åè½æ¶å 载模åbundle-preload– 卿¬å/èç¦æ¶é¢å 载以è·å¾æç¥é度
3. æå¡å¨ç«¯æ§è½ï¼é«ï¼
server-auth-actions– åAPIè·¯ç±ä¸æ ·è®¤è¯æå¡å¨æä½server-cache-react– 使ç¨React.cache()è¿è¡æ¯è¯·æ±å»éserver-cache-lru– 使ç¨LRUç¼åè¿è¡è·¨è¯·æ±ç¼åserver-dedup-props– é¿å å¨RSC propsä¸éå¤åºåå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– å°æè´µç工使åå°è®°å¿ç»ä»¶ä¸rerender-memo-with-default-value– æåé»è®¤éåå§propsrerender-dependencies– 卿æä¸ä½¿ç¨åå§ä¾èµé¡¹rerender-derived-state– è®¢é æ´¾çå¸å°å¼ï¼è䏿¯åå§å¼rerender-derived-state-no-effect– 卿¸²ææé´æ´¾çç¶æï¼è䏿¯æærerender-functional-setstate– 使ç¨å½æ°setStateè¿è¡ç¨³å®åè°rerender-lazy-state-init– å°å½æ°ä¼ éç»useState以è·åæè´µå¼rerender-simple-expression-in-memo– é¿å 对ç®ååå§å¼ä½¿ç¨memorerender-move-effect-to-event– å°äº¤äºé»è¾æ¾å¨äºä»¶å¤çç¨åºä¸rerender-transitions– 对éç´§æ¥æ´æ°ä½¿ç¨startTransitionrerender-use-ref-transient-values– å¯¹ç¬æé¢ç¹å¼ä½¿ç¨refs
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– æå¶é¢æçä¸å¹é rendering-activity– 对æ¾ç¤º/éè使ç¨Activityç»ä»¶rendering-conditional-render– 使ç¨ä¸å è¿ç®ç¬¦ï¼è䏿¯&&è¿è¡æ¡ä»¶æ¸²ærendering-usetransition-loading– ä¼å 使ç¨useTransitionè¿è¡å è½½ç¶æ
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/maxè䏿¯æåºjs-set-map-lookups– 使ç¨Set/Mapè¿è¡O(1)æ¥æ¾js-tosorted-immutable– 使ç¨toSorted()è¿è¡ä¸å¯åæ§
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