React Server ComponentïŒRSCïŒã®ããŒã·ã£ã«ã¬ã³ããªã³ã°ãšéžæçã³ã³ããŒãã³ãã¹ããªãŒãã³ã°æè¡ã解説ããŠã§ãã¢ããªã®ããã©ãŒãã³ã¹ãæé©åããåæèªã¿èŸŒã¿ãé«éåããŠUXãåäžãããæ¹æ³ãåŠã³ãŸãã
React Server Componentã®ããŒã·ã£ã«ã¬ã³ããªã³ã°ïŒéžæçã³ã³ããŒãã³ãã¹ããªãŒãã³ã°ã«ãããŠãŒã¶ãŒãšã¯ã¹ããªãšã³ã¹ã®åäž
é²åãç¶ãããŠã§ãéçºã®äžçã«ãããŠãæé©ãªããã©ãŒãã³ã¹ãšã·ãŒã ã¬ã¹ãªãŠãŒã¶ãŒãšã¯ã¹ããªãšã³ã¹ãæäŸããããšã¯æãéèŠã§ããReact Server ComponentsïŒRSCïŒã¯ãç¹ã«ããŒã·ã£ã«ã¬ã³ããªã³ã°ãéžæçã³ã³ããŒãã³ãã¹ããªãŒãã³ã°ãšãã£ãæè¡ãšçµã¿åãããããšã§ããããéæããããã®åŒ·åãªã¢ãããŒããæäŸããŸãããã®èšäºã§ã¯ãRSCã®ããŒã·ã£ã«ã¬ã³ããªã³ã°ã®è€éãã«æ·±ãå ¥ã蟌ã¿ãéžæçã³ã³ããŒãã³ãã¹ããªãŒãã³ã°ã«çŠç¹ãåœãŠããããã®æŠç¥ããŠã§ãã¢ããªã±ãŒã·ã§ã³ã®ããã©ãŒãã³ã¹ãããã«å€§å¹ ã«åäžãããããæ¢ããŸãã
React Server ComponentsïŒRSCïŒãçè§£ãã
ããŒã·ã£ã«ã¬ã³ããªã³ã°ã®è©³çްã«å ¥ãåã«ãReact Server Componentsã®åºæ¬æŠå¿µãææ¡ããããšãäžå¯æ¬ ã§ããåŸæ¥ã®ã¯ã©ã€ã¢ã³ããµã€ãReactã³ã³ããŒãã³ããšã¯ç°ãªããRSCã¯ãµãŒããŒäžã§å®è¡ãããã¯ã©ã€ã¢ã³ãã«éä¿¡ãããHTMLãçæããŸããããã«ã¯ããã€ãã®äž»èŠãªå©ç¹ããããŸãïŒ
- ã¯ã©ã€ã¢ã³ããµã€ãJavaScriptã®åæžïŒ ãµãŒããŒã§ã¬ã³ããªã³ã°ãå®è¡ããããšã§ãRSCã¯ã¯ã©ã€ã¢ã³ãã®ãã©ãŠã¶ãããŠã³ããŒãããŠå®è¡ããå¿ èŠã®ããJavaScriptã®éãæå°éã«æããåæèªã¿èŸŒã¿æéãççž®ããŸãã
- SEOã®åäžïŒ æ€çŽ¢ãšã³ãžã³ã®ã¯ããŒã©ãŒã¯RSCã«ãã£ãŠçæãããHTMLã容æã«ã€ã³ããã¯ã¹ã§ããããããŠã§ããµã€ãã®æ€çŽ¢ãšã³ãžã³æé©åïŒSEOïŒãåäžããŸãã
- ããŒã¿ãžã®çŽæ¥ã¢ã¯ã»ã¹ïŒ RSCã¯APIãšã³ããã€ã³ããå¿ èŠãšããã«ãµãŒããŒäžã®ããŒã¿ãœãŒã¹ã«çŽæ¥ã¢ã¯ã»ã¹ã§ãããããããŒã¿ååŸãç°¡çŽ åãããããã©ãŒãã³ã¹ãåäžããŸãã
å€§èŠæš¡ã³ã³ããŒãã³ããšåæèªã¿èŸŒã¿æéã®èª²é¡
RSCã«ã¯å€ãã®å©ç¹ããããŸãããå€§èŠæš¡ãŸãã¯è€éãªã³ã³ããŒãã³ããæ±ãéã«ã¯èª²é¡ãçããŸããRSCã®ãµãŒããŒã§ã®ã¬ã³ããªã³ã°ã«ããªãã®æéãããããšãããŒãžå šäœã®åæè¡šç€ºãé ãããŠãŒã¶ãŒãšã¯ã¹ããªãšã³ã¹ã«æªåœ±é¿ãäžããå¯èœæ§ããããŸããããã§ããŒã·ã£ã«ã¬ã³ããªã³ã°ãšéžæçã³ã³ããŒãã³ãã¹ããªãŒãã³ã°ã圹ç«ã¡ãŸãã
ããŒã·ã£ã«ã¬ã³ããªã³ã°ïŒã¬ã³ããªã³ã°ããã»ã¹ãåå²ãã
ããŒã·ã£ã«ã¬ã³ããªã³ã°ã§ã¯ãå€§èŠæš¡ãŸãã¯è€éãªã³ã³ããŒãã³ãããç¬ç«ããŠã¬ã³ããªã³ã°ã§ããããå°ãã管çãããããã£ã³ã¯ã«åå²ããŸããããã«ããããµãŒããŒã¯ã³ã³ããŒãã³ãå šäœãå®å šã«ã¬ã³ããªã³ã°ãããåã§ãã£ãŠããããŒãžã®ããã«å©çšå¯èœãªéšåã®HTMLãã¯ã©ã€ã¢ã³ãã«ã¹ããªãŒãã³ã°ãå§ããããšãã§ããŸããããã«ããããæåã®ãã€ããŸã§ã®æéãïŒTTFBïŒãççž®ãããããŒãžã®åæè¡šç€ºãé«éåãããŸãã
ããŒã·ã£ã«ã¬ã³ããªã³ã°ã®å©ç¹
- åæèªã¿èŸŒã¿æéã®ççž®ïŒ ãŠãŒã¶ãŒã¯ã³ã³ãã³ããããæ©ãèŠãããšãã§ããããè¯å®çãªç¬¬äžå°è±¡ã«ã€ãªãããŸãã
- äœæããã©ãŒãã³ã¹ã®åäžïŒ ããŒãžå šäœãããã«å®å šã«ã¬ã³ããªã³ã°ãããªããŠããåæã³ã³ãã³ãã®è¡šç€ºã¯é床ãšå¿çæ§ã®æèŠãçã¿åºããŸãã
- ãµãŒããŒè² è·ã®è»œæžïŒ ã³ã³ãã³ããæ®µéçã«ã¹ããªãŒãã³ã°ããããšã§ããµãŒããŒã¯åäžã®å€§ããªã¬ã³ããªã³ã°ã¿ã¹ã¯ã«å§åãããã®ãé¿ããããšãã§ããŸãã
éžæçã³ã³ããŒãã³ãã¹ããªãŒãã³ã°ïŒäž»èŠã³ã³ãã³ãã®åªå é äœä»ã
éžæçã³ã³ããŒãã³ãã¹ããªãŒãã³ã°ã¯ãããŒã·ã£ã«ã¬ã³ããªã³ã°ãããã«äžæ©é²ããéèŠãªã³ã³ãã³ããæåã«ã¯ã©ã€ã¢ã³ãã«ã¹ããªãŒãã³ã°ããããšãåªå ããŸããããã«ãããæãéèŠãªæ å ±ãã€ã³ã¿ã©ã¯ãã£ããªèŠçŽ ãå¯èœãªéãè¿ éã«è¡šç€ºããããŠãŒã¶ãŒãããŒãžãšé¢ããèœåãåäžããŸãã
eã³ããŒã¹ã®ååããŒãžãæ³åããŠã¿ãŠãã ãããéžæçã³ã³ããŒãã³ãã¹ããªãŒãã³ã°ã䜿çšãããšãååç»åãã¿ã€ãã«ãäŸ¡æ Œã®è¡šç€ºãåªå ãã顧客ã¬ãã¥ãŒãé¢é£ååã®ãããããªã©ãéèŠåºŠã®äœãã»ã¯ã·ã§ã³ã®ã¬ã³ããªã³ã°ãé å»¶ãããããšãã§ããŸãã
éžæçã³ã³ããŒãã³ãã¹ããªãŒãã³ã°ã®ä»çµã¿
- éèŠãªã³ã³ããŒãã³ãã®ç¹å®ïŒ ãŠãŒã¶ãŒãããã«èŠãŠæäœããããã«äžå¯æ¬ ãªã³ã³ããŒãã³ããæ±ºå®ããŸãã
- Suspenseã«ããã¹ããªãŒãã³ã°ã®å®è£ ïŒ React Suspenseãå©çšããŠéèŠåºŠã®äœãã³ã³ããŒãã³ããã©ããããåŸã§ã¬ã³ããªã³ã°ããã³ã¹ããªãŒãã³ã°ã§ããããšã瀺ããŸãã
- ãµãŒããŒã¬ã³ããªã³ã°ã®åªå é äœä»ãïŒ ãµãŒããŒãéèŠãªã³ã³ããŒãã³ãã®ã¬ã³ããªã³ã°ãæåã«åªå ããããã«ããŸãã
- ã³ã³ãã³ãã®æ®µéçã¹ããªãŒãã³ã°ïŒ ãµãŒããŒã¯éèŠãªã³ã³ããŒãã³ãã®HTMLãã¯ã©ã€ã¢ã³ãã«ã¹ããªãŒãã³ã°ãããã®åŸãå©çšå¯èœã«ãªã£ãéèŠåºŠã®äœãã³ã³ããŒãã³ãã®HTMLãã¹ããªãŒãã³ã°ããŸãã
React Suspenseã«ããéžæçã³ã³ããŒãã³ãã¹ããªãŒãã³ã°ã®å®è£
React Suspenseã¯ãéåææäœãã³ã³ããŒãã³ãã®é å»¶èªã¿èŸŒã¿ãåŠçããããã®åŒ·åãªã¡ã«ããºã ã§ããã¬ã³ããªã³ã°ã«æéããããå¯èœæ§ã®ããã³ã³ããŒãã³ããã©ããããã³ã³ããŒãã³ãã®æºåäžã«ãã©ãŒã«ããã¯UIïŒäŸïŒããŒãã£ã³ã°ã¹ãããŒïŒã衚瀺ããããšãã§ããŸããRSCãšçµã¿åãããããšã§ãSuspenseã¯éžæçã³ã³ããŒãã³ãã¹ããªãŒãã³ã°ã容æã«ããŸãã
äŸïŒeã³ããŒã¹ã®ååããŒãž
eã³ããŒã¹ã®ååããŒãžã®ç°¡åãªäŸã§èª¬æããŸãããã以äžã®ã³ã³ããŒãã³ãããããšä»®å®ããŸãïŒ
ProductImageïŒååç»åã衚瀺ããŸããProductTitleïŒååã¿ã€ãã«ã衚瀺ããŸããProductPriceïŒååäŸ¡æ Œã衚瀺ããŸããProductDescriptionïŒåå説æã衚瀺ããŸããCustomerReviewsïŒé¡§å®¢ã¬ãã¥ãŒã衚瀺ããŸãã
ãã®ã·ããªãªã§ã¯ãProductImageãProductTitleãProductPriceã¯éèŠãšèŠãªãããProductDescriptionãšCustomerReviewsã¯éèŠåºŠãäœããåŸã§ã¹ããªãŒãã³ã°ã§ããŸãã
以äžã¯ãReact Suspenseã䜿çšããŠéžæçã³ã³ããŒãã³ãã¹ããªãŒãã³ã°ãå®è£ ããæ¹æ³ã§ãïŒ
// ProductPage.jsx (ãµãŒããŒã³ã³ããŒãã³ã)
import { Suspense } from 'react';
import ProductImage from './ProductImage';
import ProductTitle from './ProductTitle';
import ProductPrice from './ProductPrice';
import ProductDescription from './ProductDescription';
import CustomerReviews from './CustomerReviews';
export default async function ProductPage({ productId }) {
// ååããŒã¿ãååŸããã·ãã¥ã¬ãŒã·ã§ã³ïŒããŒã¿ããŒã¹ãªã©ããïŒ
const product = await fetchProductData(productId);
return (
<div>
<ProductImage src={product.imageUrl} alt={product.name} />
<ProductTitle title={product.name} />
<ProductPrice price={product.price} />
<Suspense fallback={<p>説æãèªã¿èŸŒã¿äž...</p>}>
<ProductDescription description={product.description} />
</Suspense>
<Suspense fallback={<p>ã¬ãã¥ãŒãèªã¿èŸŒã¿äž...</p>}>
<CustomerReviews productId={productId} />
</Suspense>
</div>
);
}
ãã®äŸã§ã¯ãProductDescriptionãšCustomerReviewsã³ã³ããŒãã³ãã¯<Suspense>ã³ã³ããŒãã³ãã§ã©ãããããŠããŸãããããã®ã³ã³ããŒãã³ãããµãŒããŒã§ã¬ã³ããªã³ã°ãããŠããéããã©ãŒã«ããã¯UIïŒ<p>èªã¿èŸŒã¿äž...</p>ã®èŠçŽ ïŒã衚瀺ãããŸããã³ã³ããŒãã³ãã®æºåãæŽããšããã®HTMLãã¯ã©ã€ã¢ã³ãã«ã¹ããªãŒãã³ã°ããããã©ãŒã«ããã¯UIã眮ãæããŸãã
æ³šïŒ ãã®äŸã§ã¯ããµãŒããŒã³ã³ããŒãã³ãå ã§`async/await`ã䜿çšããŠããŸããããã«ãããããŒã¿ååŸãç°¡çŽ åãããã³ãŒãã®å¯èªæ§ãåäžããŸãã
éžæçã³ã³ããŒãã³ãã¹ããªãŒãã³ã°ã®å©ç¹
- äœæããã©ãŒãã³ã¹ã®åäžïŒ éèŠãªã³ã³ãã³ããåªå ããããšã§ããã¹ãŠã®ã³ã³ããŒãã³ããå®å šã«ã¬ã³ããªã³ã°ãããåã§ãããŠãŒã¶ãŒã¯ããæ©ãããŒãžãšå¯Ÿè©±ãå§ããããšãã§ããŸãã
- ãŠãŒã¶ãŒãšã³ã²ãŒãžã¡ã³ãã®åäžïŒ åæã®è¡šç€ºãéããšããŠãŒã¶ãŒã¯ããŒãžã«çãŸããã³ã³ãã³ããæ¢çŽ¢ããããä¿ãããŸãã
- ãªãœãŒã¹å©çšã®æé©åïŒ ã³ã³ãã³ããæ®µéçã«ã¹ããªãŒãã³ã°ããããšã§ããµãŒããŒãšã¯ã©ã€ã¢ã³ãã®äž¡æ¹ã®è² è·ã軜æžãããã¢ããªã±ãŒã·ã§ã³å šäœã®ããã©ãŒãã³ã¹ãåäžããŸãã
- äœéæ¥ç¶ã§ã®ãŠãŒã¶ãŒãšã¯ã¹ããªãšã³ã¹ã®åäžïŒ ãããã¯ãŒã¯æ¥ç¶ãé ãå Žåã§ãããŠãŒã¶ãŒã¯äžå¯æ¬ ãªã³ã³ãã³ããè¿ éã«èŠãŠæäœã§ããããããšã¯ã¹ããªãšã³ã¹ããã蚱容ã§ãããã®ã«ãªããŸãã
èæ ®äºé ãšãã¹ããã©ã¯ãã£ã¹
éžæçã³ã³ããŒãã³ãã¹ããªãŒãã³ã°ã¯å€§ããªå©ç¹ãæäŸããŸããã以äžãèæ ®ããããšãéèŠã§ãïŒ
- æ éãªã³ã³ããŒãã³ãã®åªå é äœä»ãïŒ ãŠãŒã¶ãŒãšã¯ã¹ããªãšã³ã¹ã«ãšã£ãŠæãéèŠãªã³ã³ããŒãã³ããæ£ç¢ºã«ç¹å®ããŸããééã£ãã³ã³ããŒãã³ããåªå ãããšãã¹ããªãŒãã³ã°ã®å©ç¹ãç¡å¹ã«ãªãå¯èœæ§ããããŸãããŠãŒã¶ãŒã®è¡åãåæããŒã¿ãåèã«ããŠæ±ºå®ãäžããŠãã ãããäŸãã°ããã¥ãŒã¹ãµã€ãã§ã¯ãèšäºã®èŠåºããšæåã®æ®µèœã¯ãã³ã¡ã³ãã»ã¯ã·ã§ã³ãããéèŠã§ããå¯èœæ§ãé«ãã§ãã
- 广çãªãã©ãŒã«ããã¯UIïŒ ãã©ãŒã«ããã¯UIã¯æçã§èŠèŠçã«é åçã§ããã¹ãã§ãã³ã³ãã³ããèªã¿èŸŒã¿äžã§ããããšããŠãŒã¶ãŒã«æç¢ºã«ç€ºãå¿ èŠããããŸããäžè¬çãªããŒãã£ã³ã°ã¹ãããŒã¯é¿ãã代ããã«æçµçã«è¡šç€ºãããã³ã³ãã³ãã®æ§é ãæš¡å£ãããã¬ãŒã¹ãã«ããŒã䜿çšããŸããããã¢ãã³ã§é åçãªãšã¯ã¹ããªãšã³ã¹ã®ããã«ãã·ããŒãšãã§ã¯ããã¹ã±ã«ãã³ããŒããŒã®äœ¿çšãæ€èšããŠãã ããã
- ããã©ãŒãã³ã¹ç£èŠïŒ ã¢ããªã±ãŒã·ã§ã³ã®ããã©ãŒãã³ã¹ãç¶ç¶çã«ç£èŠããæœåšçãªããã«ããã¯ãç¹å®ããã¹ããªãŒãã³ã°æŠç¥ãæé©åããŸãããã©ãŠã¶ã®éçºè ããŒã«ããµãŒããŒãµã€ãã®ç£èŠããŒã«ã䜿çšããŠãTTFBãFirst Contentful PaintïŒFCPïŒãLargest Contentful PaintïŒLCPïŒãªã©ã®ã¡ããªã¯ã¹ã远跡ããŸãã
- ç°ãªããããã¯ãŒã¯æ¡ä»¶äžã§ã®ãã¹ãïŒ æ§ã ãªãããã¯ãŒã¯æ¡ä»¶ïŒäŸïŒäœé3Gãé«éãããŒããã³ãïŒã§ã¢ããªã±ãŒã·ã§ã³ããã¹ãããã¹ããªãŒãã³ã°æŠç¥ããã¹ãŠã®ã·ããªãªã§å¹æçã«æ©èœããããšã確èªããŸãããã©ãŠã¶ã®éçºè ããŒã«ã䜿çšããŠãç°ãªããããã¯ãŒã¯é床ãšé å»¶ãã·ãã¥ã¬ãŒãããŸãã
- ãã€ãã¬ãŒã·ã§ã³ã«é¢ããèæ ®äºé ïŒ ãµãŒããŒã¬ã³ããªã³ã°ãããã³ã³ãã³ããã¹ããªãŒãã³ã°ããå Žåãã¯ã©ã€ã¢ã³ããµã€ãã®ãã€ãã¬ãŒã·ã§ã³ããã»ã¹ãå¹ççã§ããããšã確èªããããšãéèŠã§ããäžèŠãªåã¬ã³ããªã³ã°ãé¿ããã€ãã³ããã³ããªã³ã°ãæé©åããŠããã©ãŒãã³ã¹ã®åé¡ãé²ããŸããReactã®ProfilerããŒã«ã䜿çšããŠããã€ãã¬ãŒã·ã§ã³ã®ããã«ããã¯ãç¹å®ãã察åŠããŸãã
ããŒã«ãšãã¯ãããžãŒ
- React SuspenseïŒ éžæçã³ã³ããŒãã³ãã¹ããªãŒãã³ã°ãå®è£ ããããã®ã³ã¢ã¡ã«ããºã ã
- Next.jsïŒ ãµãŒããŒãµã€ãã¬ã³ããªã³ã°ãšã¹ããªãŒãã³ã°ãçµã¿èŸŒã¿ã§ãµããŒããã人æ°ã®Reactãã¬ãŒã ã¯ãŒã¯ãNext.jsã¯RSCã®å®è£ ãç°¡çŽ åããããã©ãŒãã³ã¹ãæé©åããããã®ãŠãŒãã£ãªãã£ãæäŸããŸãã
- RemixïŒ ãµãŒããŒãµã€ãã¬ã³ããªã³ã°æ©èœãåããå¥ã®Reactãã¬ãŒã ã¯ãŒã¯ã§ãNext.jsãšã¯ç°ãªãããŒã¿èªã¿èŸŒã¿ãšã«ãŒãã£ã³ã°ã®ã¢ãããŒããæäŸããŸããRemixã¯ãŠã§ãæšæºãéèŠããããã°ã¬ãã·ããšã³ãã³ã¹ã¡ã³ãã匷åã«ãµããŒãããŸãã
- ãã©ãŠã¶éçºè ããŒã«ïŒ ãããã¯ãŒã¯ããã©ãŒãã³ã¹ãåæããã¬ã³ããªã³ã°ã®ããã«ããã¯ãç¹å®ããããã«äžå¯æ¬ ã§ãã
- ãµãŒããŒãµã€ãç£èŠããŒã«ïŒ New RelicãDatadogãSentryãªã©ã®ããŒã«ã¯ããµãŒããŒãµã€ãã®ããã©ãŒãã³ã¹ã«é¢ããæŽå¯ãæäŸããã¹ããªãŒãã³ã°ã«åœ±é¿ãäžããå¯èœæ§ã®ããåé¡ãç¹å®ããã®ã«åœ¹ç«ã¡ãŸãã
å®äžçã®äŸãšã±ãŒã¹ã¹ã¿ãã£
ããã€ãã®äŒæ¥ãRSCãšéžæçã³ã³ããŒãã³ãã¹ããªãŒãã³ã°ãæåè£ã«å®è£ ãããŠã§ãã¢ããªã±ãŒã·ã§ã³ã®ããã©ãŒãã³ã¹ãåäžãããŠããŸããå ·äœçãªè©³çŽ°ã¯æ©å¯ã§ããããšãå€ãã§ãããäžè¬çãªå©ç¹ã¯åºãèªèãããŠããŸãã
- Eã³ããŒã¹ãã©ãããã©ãŒã ïŒ Eã³ããŒã¹ãµã€ãã¯ãååæ å ±ã®è¡šç€ºãåªå ããéèŠåºŠã®äœãèŠçŽ ã®ã¬ã³ããªã³ã°ãé ãããããšã§ãããŒãžèªã¿èŸŒã¿æéãšã³ã³ããŒãžã§ã³çã®å€§å¹ ãªæ¹åãèŠãŠããŸããããšãŒãããã®å€§æãªã³ã©ã€ã³å°å£²æ¥è ã¯ãåæ§ã®æŠç¥ãå®è£ ããåŸãã³ã³ããŒãžã§ã³çã15%åäžãããšå ±åããŠããŸãã
- ãã¥ãŒã¹ãŠã§ããµã€ãïŒ ãã¥ãŒã¹æ©é¢ã¯ãé¢é£èšäºãåºåãèªã¿èŸŒãåã«èšäºã®èŠåºããšã³ã³ãã³ããã¹ããªãŒãã³ã°ããããšã§ãéå ±ãããè¿ éã«é ä¿¡ã§ããããã«ãªããŸãããã¢ãžã¢ã®å€§æãã¥ãŒã¹ã¡ãã£ã¢ã¯ãéžæçã³ã³ããŒãã³ãã¹ããªãŒãã³ã°ãæ¡çšããåŸãçŽåž°çã20%æžå°ãããšå ±åããŠããŸãã
- ãœãŒã·ã£ã«ã¡ãã£ã¢ãã©ãããã©ãŒã ïŒ ãœãŒã·ã£ã«ã¡ãã£ã¢ãµã€ãã¯ãã¡ã€ã³ã®ã³ã³ãã³ããã£ãŒãã®è¡šç€ºãåªå ãããµã€ãããŒèŠçŽ ãã³ã¡ã³ãã»ã¯ã·ã§ã³ã®èªã¿èŸŒã¿ãé ãããããšã§ããŠãŒã¶ãŒãšã¯ã¹ããªãšã³ã¹ãåäžãããŠããŸããåç±³ã®å€§æãœãŒã·ã£ã«ã¡ãã£ã¢äŒæ¥ã¯ããã®ã¢ãããŒããå®è£ ããåŸããŠãŒã¶ãŒãšã³ã²ãŒãžã¡ã³ãã10%åäžãããšèŠãŠããŸãã
çµè«
React Server Componentã®ããŒã·ã£ã«ã¬ã³ããªã³ã°ãç¹ã«éžæçã³ã³ããŒãã³ãã¹ããªãŒãã³ã°ã掻çšããããšã¯ããŠã§ãã¢ããªã±ãŒã·ã§ã³ã®ããã©ãŒãã³ã¹æé©åã«ããã倧ããªé²æ©ã衚ããŠããŸããéèŠãªã³ã³ãã³ããåªå ãããããæ®µéçã«ã¯ã©ã€ã¢ã³ãã«ã¹ããªãŒãã³ã°ããããšã§ãããéããããé åçãªãŠãŒã¶ãŒãšã¯ã¹ããªãšã³ã¹ãæäŸã§ããŸããå®è£ ã«ã¯æ éãªèšç»ãšèæ ®ãå¿ èŠã§ãããããã©ãŒãã³ã¹ãšãŠãŒã¶ãŒæºè¶³åºŠã®é¢ã§ã®å©ç¹ã¯ããã®åŽåã«èŠåã䟡å€ããããŸããReactãšã³ã·ã¹ãã ãé²åãç¶ããäžã§ãRSCãšã¹ããªãŒãã³ã°æè¡ã¯ãã°ããŒãã«ãªèŠèŽè ã®èŠæ±ã«å¿ãã髿§èœãªãŠã§ãã¢ããªã±ãŒã·ã§ã³ãæ§ç¯ããããã®äžå¯æ¬ ãªããŒã«ã«ãªãæ å¢ãæŽã£ãŠããŸãã
ãããã®æŠç¥ãåãå ¥ããããšã§ãããéããããå¿çæ§ãé«ãã ãã§ãªããäžçäžã®ãŠãŒã¶ãŒã«ãšã£ãŠããã¢ã¯ã»ã¹ãããããé åçãªãŠã§ãã¢ããªã±ãŒã·ã§ã³ãäœæããããšãã§ããŸãã