Цей документ було перекладено за допомогою ШІ. Для точної інформації зверніться до англійської версії.
RunJS підтримує синтаксис JSX, що дозволяє писати код подібно до компонентів React. JSX автоматично компілюється перед виконанням.
ctx.libs.React.createElement та ctx.libs.React.Fragment.ctx.libs.React.ctx.importAsync('react@x.x.x'), JSX переключиться на використання методу createElement саме з цього екземпляра.RunJS містить вбудований React та популярні бібліотеки UI. Ви можете отримати доступ до них безпосередньо через ctx.libs без використання import:
createRoot, якщо потрібно)При написанні JSX безпосередньо вам не потрібно деструктурувати React. Це необхідно лише при використанні Hooks (таких як useState, useEffect) або Fragment (<>...</>):
Примітка: Вбудований React та зовнішній React, імпортований через ctx.importAsync(), не можна змішувати. Якщо ви використовуєте зовнішню бібліотеку UI, React також має бути імпортований з того ж зовнішнього джерела.
При завантаженні конкретної версії React та бібліотек UI через ctx.importAsync(), JSX використовуватиме цей екземпляр React:
Якщо antd залежить від react/react-dom, ви можете вказати ту саму версію через deps, щоб уникнути створення кількох екземплярів:
Примітка: При використанні зовнішнього React бібліотеки UI, такі як antd, також повинні бути імпортовані через ctx.importAsync(). Не змішуйте їх із ctx.libs.antd.
<Button type="primary">Текст</Button><>...</> або <React.Fragment>...</React.Fragment> (при використанні Fragment необхідно деструктурувати const { React } = ctx.libs){вираз} у JSX для вставки змінних або операцій, наприклад {ctx.user.name} або {count + 1}. Не використовуйте синтаксис шаблонів {{ }}.{flag && <span>Вміст</span>} або {flag ? <A /> : <B />}array.map() для повернення списку елементів і переконайтеся, що кожен елемент має стабільний key.