Reactã®experimental_LegacyHiddenæ©èœãæ¢æ±ããã¬ã¬ã·ãŒã³ã³ããŒãã³ãã®ã¬ã³ããªã³ã°ãžã®åœ±é¿ãããã©ãŒãã³ã¹æé©åæŠç¥ãã¢ãã³Reactã¢ããªã®ãã¹ããã©ã¯ãã£ã¹ã解説ããŸãã
ããã©ãŒãã³ã¹ã®è§£æŸïŒReactã®experimental_LegacyHiddenæ©èœã®æ·±æã
Reactã¯é²åãç¶ããããã©ãŒãã³ã¹ã®åäžãšéçºè
äœéšã®æ¹åãç®çãšããæ©èœãå°å
¥ããŠããŸãããã®ãããªæ©èœã®äžã€ããçŸåšå®éšçãªexperimental_LegacyHiddenã§ãããã®ããã°èšäºã§ã¯ããã®æ©èœã®è€éãªè©³çްãæãäžãããã®ç®çãå©ç¹ããããŠå®çšçãªå¿çšäŸãæ¢ããŸããç¹ã«ãã¢ãã³ãªReactã¢ããªã±ãŒã·ã§ã³å
ã§ã¬ã¬ã·ãŒã³ã³ããŒãã³ãã®ã¬ã³ããªã³ã°ãæé©åããæ¹æ³ã«çŠç¹ãåœãŠãŸãããŸããæœåšçãªæ¬ ç¹ã广çãªå®è£
ã®ããã®ãã¹ããã©ã¯ãã£ã¹ã«ã€ããŠãè°è«ããŸãã
experimental_LegacyHiddenãšã¯äœãïŒ
experimental_LegacyHiddenã¯ãReactã®æ©èœïŒConcurrent Featuresãã¡ããªãŒã®äžéšïŒã§ãããã³ã³ããŒãã³ãã®å¯èŠæ§ãå¶åŸ¡ãã€ã€ãReactãããã¯ã°ã©ãŠã³ãã§ãã®ã¬ã³ããªã³ã°äœæ¥ãç¶ç¶ã§ããããã«ããã¡ã«ããºã ãæäŸããŸããããã¯ç¹ã«ãèšç®ã³ã¹ããé«ãå¯èœæ§ã®ããããŸãã¯ç»é¢ã«ããã«ã¯è¡šç€ºãããªãã¬ã¬ã·ãŒã³ã³ããŒãã³ãã®ããã©ãŒãã³ã¹ãæé©åããã®ã«åœ¹ç«ã¡ãŸããããã¯ã°ã©ãŠã³ãã§ã®äºåã¬ã³ããªã³ã°ãšãã远å ã®å©ç¹ãåãããèŠçŽ ãæ¡ä»¶ä»ãã§ã¬ã³ããªã³ã°ããæŽç·Žãããæ¹æ³ãšèããŠãã ããã
æ¬è³ªçã«ãexperimental_LegacyHiddenã¯ãã³ã³ããŒãã³ããããŠã³ãããããŸãŸé衚瀺ã«ããããšãå¯èœã«ããŸããããã«ãããReactã¯çŸåšè¡šç€ºãããŠããªããŠããããã¯ã°ã©ãŠã³ãã§ã³ã³ããŒãã³ãã®æŽæ°ãåŠçãã倿Žãã¬ã³ããªã³ã°ãç¶ããããšãã§ããŸããã³ã³ããŒãã³ãã衚瀺ããå¿
èŠããããšãã«ã¯ããã§ã«äºåã¬ã³ããªã³ã°ãããŠããããããŠãŒã¶ãŒã«ãšã£ãŠããé«éã§ã¹ã ãŒãºãªé·ç§»ãå®çŸããŸãã
ãªãexperimental_LegacyHiddenã䜿çšããã®ãïŒ
experimental_LegacyHiddenã®äž»ãªåæ©ã¯ãç¹ã«ä»¥äžã®ãããªã±ãŒã¹ã§äœæããã©ãŒãã³ã¹ãåäžãããããšã§ãïŒ
- ã¬ã¬ã·ãŒã³ã³ããŒãã³ãïŒ ã¢ãã³ãªReactã®ã¬ã³ããªã³ã°ãã¿ãŒã³ã«æé©åãããŠããªãå€ãã³ã³ããŒãã³ãããããã®ã³ã³ããŒãã³ãã¯ãã°ãã°ããã©ãŒãã³ã¹ã®ããã«ããã¯ã«ãªãããšããããŸããäŸãã°ãåæçãªæäœã«å€§ããäŸåããããã¬ã³ããªã³ã°äžã«è€éãªèšç®ãå®è¡ãããããã³ã³ããŒãã³ããèããŠã¿ãŠãã ããã
- åæç¶æ
ã§ç»é¢å€ã«ããã³ã³ããŒãã³ãïŒ ã¿ããã¢ã³ãŒãã£ãªã³ããŸãã¯ã¢ãŒãã«ãŠã£ã³ããŠã®èåŸã«ãããããªãããã«ã¯è¡šç€ºãããªãèŠçŽ ãåã¿ãã«è€éãªãã£ãŒããå«ãŸããããã·ã¥ããŒããæ³åããŠãã ããã
experimental_LegacyHiddenã䜿çšãããšãéã¢ã¯ãã£ããªã¿ãã®ãã£ãŒããäºåã¬ã³ããªã³ã°ã§ãããŠãŒã¶ãŒãåãæ¿ãããšãã«å³åº§ã«èªã¿èŸŒãŸããŸãã - é«ã³ã¹ããªã³ã³ããŒãã³ãïŒ ã¬ã¬ã·ãŒã§ãããã©ããã«ããããããã¬ã³ããªã³ã°ã«ããªãã®æéãèŠããã³ã³ããŒãã³ããããã¯ãè€éãªèšç®ãå€§èŠæš¡ãªããŒã¿ã»ããããŸãã¯å ¥ãçµãã UIæ§é ãåå ã§ããå¯èœæ§ããããŸãã
- æ¡ä»¶ä»ãã¬ã³ããªã³ã°ïŒ ãŠãŒã¶ãŒã®æäœã«åºã¥ããŠã³ã³ããŒãã³ããæ¡ä»¶ä»ãã§ã¬ã³ããªã³ã°ãããéã®ãé·ç§»ãšäœæããã©ãŒãã³ã¹ã®åäžã
experimental_LegacyHiddenãæŽ»çšããããšã§ã以äžã®ããšãå¯èœã«ãªããŸãïŒ
- åæèªã¿èŸŒã¿æéãççž®ïŒ éèŠã§ãªãã³ã³ããŒãã³ãã®ã¬ã³ããªã³ã°ãé å»¶ãããŸãã
- å¿çæ§ãåäžïŒ ããã¯ã°ã©ãŠã³ãã§ã³ã³ããŒãã³ããäºåã¬ã³ããªã³ã°ããããšã§ãããã¹ã ãŒãºãªãŠãŒã¶ãŒäœéšãä¿èšŒããŸãã
- ãžã£ã³ã¯ïŒã«ã¯ã€ãïŒãæå°åïŒ é«ã³ã¹ããªã¬ã³ããªã³ã°æäœã«ããUIã®ããªãŒãºãé²ããŸãã
experimental_LegacyHiddenã®å®è£
æ¹æ³
experimental_LegacyHidden APIã¯æ¯èŒçåçŽã§ãã以äžã«åºæ¬çãªäŸã瀺ããŸãïŒ
import { unstable_LegacyHidden as LegacyHidden } from 'react';
function MyComponent() {
const [isVisible, setIsVisible] = React.useState(false);
return (
);
}
function ExpensiveLegacyComponent() {
// ãã®ã³ã³ããŒãã³ãã¯è€éãªèšç®ãã¬ã³ããªã³ã°ãè¡ãå¯èœæ§ããããŸã
return This is an expensive legacy component.
;
}
説æïŒ
unstable_LegacyHiddenãLegacyHiddenãšããŠã€ã³ããŒãããŸããunstable_ãšããæ¥é èŸã¯ãAPIããŸã å®éšçã§ããã倿Žãããå¯èœæ§ãããããšã瀺ããŠããŸããExpensiveLegacyComponentãLegacyHiddenã³ã³ããŒãã³ãã§ã©ããããŸããvisibleããããã£ãExpensiveLegacyComponentã®å¯èŠæ§ãå¶åŸ¡ããŸããvisibleãtrueã®å Žåãã³ã³ããŒãã³ãã衚瀺ãããŸããvisibleãfalseã®å Žåãã³ã³ããŒãã³ãã¯é衚瀺ã«ãªããŸãããReactã¯ããã¯ã°ã©ãŠã³ãã§ãã®äœæ¥ãç¶ããããšãã§ããŸãã
å®è·µçãªäŸãšãŠãŒã¹ã±ãŒã¹
experimental_LegacyHiddenãå®éã®ã·ããªãªã§ã©ã®ããã«äœ¿çšã§ããããããå®è·µçãªäŸãããã€ãèŠãŠã¿ãŸãããïŒ
1. ã¿ãä»ãã€ã³ã¿ãŒãã§ãŒã¹
åã¿ãã«è€éãªãã£ãŒããããŒã¿ã°ãªãããå«ãŸããã¿ãä»ãã€ã³ã¿ãŒãã§ãŒã¹ãæã€Webã¢ããªã±ãŒã·ã§ã³ãæ³åããŠã¿ãŠãã ããããã¹ãŠã®ã¿ããæåããã¬ã³ããªã³ã°ãããšãåæèªã¿èŸŒã¿æéã«å€§ããªåœ±é¿ãäžããå¯èœæ§ããããŸããexperimental_LegacyHiddenã䜿çšããããšã§ãéã¢ã¯ãã£ããªã¿ããããã¯ã°ã©ãŠã³ãã§äºåã¬ã³ããªã³ã°ãããŠãŒã¶ãŒãã¿ããåãæ¿ããéã«ã¹ã ãŒãºãªé·ç§»ãä¿èšŒã§ããŸãã
import { unstable_LegacyHidden as LegacyHidden } from 'react';
function TabPanel({ tabId, children, activeTab }) {
return (
{children}
);
}
function App() {
const [activeTab, setActiveTab] = React.useState('tab1');
return (
- setActiveTab('tab1')}>Tab 1
- setActiveTab('tab2')}>Tab 2
- setActiveTab('tab3')}>Tab 3
);
}
ãã®äŸã§ã¯ãã¢ã¯ãã£ããªã¿ãã®ã³ã³ãã³ãã®ã¿ã衚瀺ãããŸããããããReactã¯éã¢ã¯ãã£ããªã¿ãã®ã³ã³ãã³ããããã¯ã°ã©ãŠã³ãã§ã¬ã³ããªã³ã°ãç¶ããããšãã§ããããããŠãŒã¶ãŒãã¯ãªãã¯ãããšãã«å³åº§ã«è¡šç€ºãããæºåãã§ããŠããŸããããã¯ç¹ã«ExpensiveChartãã¬ã³ããªã³ã°ã«ããªãã®æéãèŠããå Žåã«å¹æçã§ãã
2. ã¢ãŒãã«ãŠã£ã³ããŠ
ã¢ãŒãã«ãŠã£ã³ããŠã«ã¯ãè€éãªãã©ãŒã ãããŒã¿è¡šç€ºãå«ãŸããããšããããããŸãããŠãŒã¶ãŒããã¿ã³ãã¯ãªãã¯ãããšãã«ã¢ãŒãã«ãã¬ã³ããªã³ã°ãããã®ãåŸ
ã€ä»£ããã«ãexperimental_LegacyHiddenã䜿çšããŠã¢ãŒãã«ãããã¯ã°ã©ãŠã³ãã§äºåã¬ã³ããªã³ã°ããã¹ã ãŒãºã«è¡šç€ºãããããšãã§ããŸãã
import { unstable_LegacyHidden as LegacyHidden } from 'react';
function Modal({ isOpen, onClose, children }) {
return (
{children}
);
}
function App() {
const [isModalOpen, setIsModalOpen] = React.useState(false);
return (
setIsModalOpen(false)}>
);
}
ããã§ã¯ãisOpenãfalseã®å ŽåãModalã³ã³ããŒãã³ãã¯é衚瀺ã«ãªããŸãããReactã¯ããã¯ã°ã©ãŠã³ãã§ãã®ã³ã³ãã³ããã¬ã³ããªã³ã°ãç¶ããããšãã§ããŸããããã«ãããç¹ã«ExpensiveFormãè€éãªã³ã³ããŒãã³ãã§ããå ŽåããŠãŒã¶ãŒããOpen Modalããã¿ã³ãã¯ãªãã¯ãããšãã¢ãŒãã«ãå³åº§ã«éãããã«èŠããŸãã
3. ã¢ã³ãŒãã£ãªã³ã³ã³ããŒãã³ã
ã¿ããšåæ§ã«ãã¢ã³ãŒãã£ãªã³ã³ã³ããŒãã³ããexperimental_LegacyHiddenã®æ©æµãåããããšãã§ããŸããéããããã»ã¯ã·ã§ã³ã®ã³ã³ãã³ããäºåã¬ã³ããªã³ã°ããããšã§ããŠãŒã¶ãŒãããããéãããšãã®äœæããã©ãŒãã³ã¹ãåäžããŸãã
import { unstable_LegacyHidden as LegacyHidden } from 'react';
function AccordionItem({ title, children, isOpen, onToggle }) {
return (
{children}
);
}
function App() {
const [openItem, setOpenItem] = React.useState(null);
const handleToggle = (itemId) => {
setOpenItem(openItem === itemId ? null : itemId);
};
return (
handleToggle('section1')}
>
handleToggle('section2')}
>
);
}
ãã®å ŽåãéããŠããã¢ã³ãŒãã£ãªã³ã¢ã€ãã ã®ã³ã³ãã³ãã®ã¿ã衚瀺ãããŸããReactã¯éããŠããã¢ã³ãŒãã£ãªã³ã¢ã€ãã ã®ã³ã³ãã³ããããã¯ã°ã©ãŠã³ãã§äºåã¬ã³ããªã³ã°ã§ããããããŠãŒã¶ãŒãããããéãéã«ããé«éãªé·ç§»ãä¿èšŒãããŸãããªãœãŒã¹ã倧éã«æ¶è²»ããExpensiveContentã³ã³ããŒãã³ãã¯ãããã¯ã°ã©ãŠã³ãã§äºåã¬ã³ããªã³ã°ãããããšã§å€§ããªæ©æµãåããã§ãããã
èæ ®äºé ãšæœåšçãªæ¬ ç¹
experimental_LegacyHiddenã¯åŒ·åãªããŒã«ãšãªãåŸãŸããããã®å¶éãšæœåšçãªæ¬ ç¹ãèªèããããšãéèŠã§ãïŒ
- åæã¬ã³ããªã³ã°ã³ã¹ãã®å¢å ïŒ ããã¯ã°ã©ãŠã³ãã§ã³ã³ããŒãã³ããäºåã¬ã³ããªã³ã°ãããšãåæã¬ã³ããªã³ã°ã³ã¹ããå¢å ããFirst Meaningful PaintïŒTTFMPïŒãŸã§ã®æéã«åœ±é¿ãäžããå¯èœæ§ããããŸããå©ç¹ãã³ã¹ããäžåãããšã確èªããããã«ã¯ãæ
éãªãããã¡ã€ãªã³ã°ãå¿
èŠã§ããç¹å®ã®ã¢ããªã±ãŒã·ã§ã³ã§
experimental_LegacyHiddenã䜿çšããããšã«ããããã©ãŒãã³ã¹ãžã®åœ±é¿ã枬å®ããããšãäžå¯æ¬ ã§ãã - ã¡ã¢ãªäœ¿çšéïŒ é衚瀺ã®å Žåã§ãã³ã³ããŒãã³ããããŠã³ããããŸãŸã«ãããšãã¡ã¢ãªäœ¿çšéãå¢å ããå¯èœæ§ããããŸããããã¯ããªãœãŒã¹ãéãããŠããããã€ã¹ã§ã¯ç¹ã«èæ ®ãã¹ãéèŠäºé ã§ãã
- è€éãïŒ
experimental_LegacyHiddenãå°å ¥ãããšãã³ãŒããè€éã«ãªããŸãããããã©ã®ããã«æ©èœãããã€äœ¿çšããã®ãé©åããæç¢ºã«çè§£ããããšãéèŠã§ãã - å®éšçãªAPIïŒ ååã瀺ãããã«ã
experimental_LegacyHiddenã¯å®éšçãªAPIã§ãããå°æ¥ã®Reactã®ããŒãžã§ã³ã§å€æŽãŸãã¯åé€ãããå¯èœæ§ããããŸãããããã£ãŠãå¿ èŠã«å¿ããŠã³ãŒããæŽæ°ããæºåãããŠããå¿ èŠããããŸãã - äžèœè¬ã§ã¯ãªãïŒ
experimental_LegacyHiddenã¯ã³ã³ããŒãã³ããæé©åãã代ããã«ãªããã®ã§ã¯ãããŸãããããã¯äœæããã©ãŒãã³ã¹ãåäžãããããã«äœ¿çšã§ããè£å®çãªãã¯ããã¯ã§ãããã³ã³ããŒãã³ãèªäœã®æ ¹æ¬çãªããã©ãŒãã³ã¹åé¡ã«å¯ŸåŠããããšãäžå¯æ¬ ã§ãã
ãã¹ããã©ã¯ãã£ã¹
experimental_LegacyHiddenã广çã«äœ¿çšããããã«ã¯ã以äžã®ãã¹ããã©ã¯ãã£ã¹ã«åŸã£ãŠãã ããïŒ
- ã¢ããªã±ãŒã·ã§ã³ããããã¡ã€ãªã³ã°ããïŒ
experimental_LegacyHiddenãå®è£ ããåã«ãReact DevToolsãä»ã®ãããã¡ã€ãªã³ã°ããŒã«ã䜿çšããŠããã©ãŒãã³ã¹ã®ããã«ããã¯ãç¹å®ããŸãããã¹ãŠã®ã³ã³ããŒãã³ãã«ç²ç®çã«é©çšããã®ã§ã¯ãªããå®éã«ããã©ãŒãã³ã¹åé¡ãåŒãèµ·ãããŠãããã®ã«çŠç¹ãåœãŠãŸãã - ããã©ãŒãã³ã¹ã枬å®ããïŒ
experimental_LegacyHiddenãå®è£ ããåŸãLighthouseãWebPageTestãªã©ã®ããŒã«ã䜿çšããŠããã©ãŒãã³ã¹ãžã®åœ±é¿ã枬å®ããŸããäœæããã©ãŒãã³ã¹ãå®éã«åäžããŠããããšã確èªããŠãã ããã - æ§ããã«äœ¿çšããïŒ
experimental_LegacyHiddenã䜿ããããªãã§ãã ãããæ¬åœã«ã¬ã³ããªã³ã°ã«ã³ã¹ãããããã³ã³ããŒãã³ãããããã«ã¯è¡šç€ºãããªãã³ã³ããŒãã³ãã«ã®ã¿é©çšããŸãã - ãŸãã³ã³ããŒãã³ããæé©åããïŒ
experimental_LegacyHiddenã«é Œãåã«ãã¡ã¢åãé å»¶èªã¿èŸŒã¿ãã³ãŒãåå²ãªã©ã®ä»ã®ãã¯ããã¯ã䜿çšããŠã³ã³ããŒãã³ããæé©åããŠã¿ãŠãã ããã - ä»£æ¿æ¡ãæ€èšããïŒ ä»®æ³åïŒå€§èŠæš¡ãªãªã¹ãåãïŒããµãŒããŒãµã€ãã¬ã³ããªã³ã°ïŒåæèªã¿èŸŒã¿æéã®æ¹ååãïŒãªã©ãä»ã®ããã©ãŒãã³ã¹æé©åãã¯ããã¯ãæ¢æ±ããŸãã
- ææ°ã®ç¶æ
ãä¿ã€ïŒ Reactã®ææ°ã®ååã
experimental_LegacyHiddenAPIã®é²åã«ã€ããŠåžžã«æ å ±ãå ¥æããŠãã ããã
experimental_LegacyHiddenã®ä»£æ¿æ¡
experimental_LegacyHiddenã¯ããã©ãŒãã³ã¹æé©åãžã®ç¹å®ã®ã¢ãããŒããæäŸããŸããããããšã¯ç¬ç«ããŠããŸãã¯çµã¿åãããŠäœ¿çšã§ããããã€ãã®ä»£æ¿ãã¯ããã¯ããããŸãïŒ
- React.lazyãšSuspenseïŒ ãããã®æ©èœã䜿çšãããšãã³ã³ããŒãã³ããé å»¶èªã¿èŸŒã¿ããå®éã«å¿ èŠã«ãªããŸã§ã¬ã³ããªã³ã°ãé ãããããšãã§ããŸããããã¯ãåæè¡šç€ºãããªãã³ã³ããŒãã³ãã«ãšã£ãŠåªããä»£æ¿æ¡ãšãªãåŸãŸãã
- ã¡ã¢åïŒReact.memoïŒïŒ ã¡ã¢åã¯ãããããã£ã倿ŽãããŠããªãå Žåã«ã³ã³ããŒãã³ããäžå¿ èŠã«åã¬ã³ããªã³ã°ãããã®ãé²ããŸããããã«ãããç¹ã«çŽç²ãªé¢æ°ã³ã³ããŒãã³ãã®ããã©ãŒãã³ã¹ãå€§å¹ ã«åäžããŸãã
- ã³ãŒãåå²ïŒ ã¢ããªã±ãŒã·ã§ã³ã®ã³ãŒããããå°ããªãã£ã³ã¯ã«åå²ããããšã§ãåæèªã¿èŸŒã¿æéãççž®ããäœæããã©ãŒãã³ã¹ãåäžãããããšãã§ããŸãã
- ä»®æ³åïŒ å€§èŠæš¡ãªãªã¹ããããŒãã«ã®å Žåãä»®æ³åæè¡ã¯è¡šç€ºãããŠããã¢ã€ãã ã®ã¿ãã¬ã³ããªã³ã°ããã¬ã³ããªã³ã°ã®ãªãŒããŒããããå€§å¹ ã«åæžããŸãã
- ãããŠã³ã¹ãšã¹ããããªã³ã°ïŒ ãããã®ãã¯ããã¯ã¯ã颿°ãå®è¡ãããã¬ãŒããå¶éããã¹ã¯ããŒã«ããªãµã€ãºãªã©ã®é »ç¹ãªã€ãã³ãã«å¿çããŠéå°ãªåã¬ã³ããªã³ã°ãé²ããŸãã
- ãµãŒããŒãµã€ãã¬ã³ããªã³ã°ïŒSSRïŒïŒ SSRã¯ããµãŒããŒã§åæHTMLãã¬ã³ããªã³ã°ããŠã¯ã©ã€ã¢ã³ãã«éä¿¡ããããšã§ãåæèªã¿èŸŒã¿æéãæ¹åã§ããŸãã
çµè«
experimental_LegacyHiddenã¯ãReactã¢ããªã±ãŒã·ã§ã³ã®ããã©ãŒãã³ã¹ãæé©åããããã®åŒ·åãªããŒã«ã§ãããç¹ã«ã¬ã¬ã·ãŒã³ã³ããŒãã³ããå³åº§ã«è¡šç€ºãããªãã³ã³ããŒãã³ããæ±ãå Žåã«æå¹ã§ããããã¯ã°ã©ãŠã³ãã§ã³ã³ããŒãã³ããäºåã¬ã³ããªã³ã°ããããšã«ãããäœæããã©ãŒãã³ã¹ã倧å¹
ã«åäžãããããã¹ã ãŒãºãªãŠãŒã¶ãŒäœéšãæäŸã§ããŸãããã ããå®è£
ããåã«ãã®å¶éãæœåšçãªæ¬ ç¹ãããã³ãã¹ããã©ã¯ãã£ã¹ãçè§£ããããšãéèŠã§ããã¢ããªã±ãŒã·ã§ã³ããããã¡ã€ãªã³ã°ããããã©ãŒãã³ã¹ã枬å®ããä»ã®ããã©ãŒãã³ã¹æé©åæè¡ãšçµã¿åãããŠè³¢æã«äœ¿çšããããšãå¿ããªãã§ãã ããã
Reactãé²åãç¶ããã«ã€ããŠãexperimental_LegacyHiddenã®ãããªæ©èœã¯ã髿§èœãªWebã¢ããªã±ãŒã·ã§ã³ãæ§ç¯ããäžã§ãŸããŸãéèŠãªåœ¹å²ãæããã§ããããåžžã«æ
å ±ãå
¥æãããããã®æ©èœã詊ãããšã§ãéçºè
ã¯ãåºç€ãšãªãã³ã³ããŒãã³ãã®è€éãã«é¢ä¿ãªããã¢ããªã±ãŒã·ã§ã³ãå¯èœãªéãæé«ã®ãŠãŒã¶ãŒäœéšãæäŸã§ããããã«ä¿èšŒã§ããŸããexperimental_LegacyHiddenããã®ä»ã®ãšããµã€ãã£ã³ã°ãªããã©ãŒãã³ã¹é¢é£æ©èœã«é¢ããææ°æ
å ±ã«ã€ããŠã¯ãReactã®ããã¥ã¡ã³ããã³ãã¥ããã£ã®è°è«ã«æ³šç®ããŠãã ããã