React без JSX
JSX не є вимогою для роботи з React. Використання React без JSX є найзручнішим тоді, коли ви не бажаєте налаштовувати компіляцію у вашому середовищі збірки.
Кожен JSX-елемент являє собою “синтаксичний цукор” для виклику React.createElement(component, props, ...children)
. Отже, все що можна зробити за допомогою JSX, може також бути виконаним на чистому JavaScript.
Наприклад, ось код на JSX:
class Hello extends React.Component {
render() {
return <div>Привіт, {this.props.toWhat}</div>;
}
}
ReactDOM.render(
<Hello toWhat="світе" />,
document.getElementById('root')
);
Його можна переписати таким чином, що JSX не буде використовуватися:
class Hello extends React.Component {
render() {
return React.createElement('div', null, `Привіт, ${this.props.toWhat}`);
}
}
ReactDOM.render(
React.createElement(Hello, {toWhat: 'світе'}, null),
document.getElementById('root')
);
Якщо ви зацікавлені в інших прикладах того, як JSX компілюється в JavaScript-код, спробуйте онлайн Babel-компілятор.
Компонент може бути представлений у вигляді рядку, як підклас React.Component
або у вигляді звичайної функції.
Якщо вас втомлює написання React.createElement
, поширеною практикою є призначення “скорочення”:
const e = React.createElement;
ReactDOM.render(
e('div', null, 'Привіт, світе'),
document.getElementById('root')
);
Якщо ви використаєте дане скорочення для React.createElement
, то робота з React без JSX буде такою ж зручною.
Також ви можете ознайомитися з іншими проектами, як react-hyperscript
і hyperscript-helpers
, які пропонують більш короткий синтаксис.