JSX Runtime
JSXを書いている利用者は特に意識することはない
React本家のblog
参考
従来
tsimport React from 'react';
function App() {
return <h1>Hello World</h1>;
}
従来
tsimport React from 'react';
function App() {
return React.createElement('h1', null, 'Hello world');
}
Reactのimportが必要
今後
tsimport {jsx as _jsx} from 'react/jsx-runtime';
function App() {
return _jsx('h1', { children: 'Hello world' });
}
JSXからJSに変換する結果が変わった
内部でのパフォーマンスの最適化をしやすくなる
当時はclassでcomponentを書くのが普通だったので、それに適していた
しかし、functional componentには適していない
React.createElement
は、JSXの実装として意図したものではなく、当時のツールでできる最善のものだった
JSXが糖衣構文であることに留意する
data:image/s3,"s3://crabby-images/6909e/6909e479c8a80b7a95155552c64ee71be78e5662" alt="mrsekut mrsekut"
React.createElementは自分で書くことも意図されていた
jsxではなく、素のreactを書く、みたいな言い方がされていたと思う
data:image/s3,"s3://crabby-images/6909e/6909e479c8a80b7a95155552c64ee71be78e5662" alt="mrsekut mrsekut"
パフォーマンスの最適化がやりづらい
childrenの扱いが、transpile時に決定できるのにruntime時にやってて効率が悪い
buid sizeが少し小さくなる
明示的にReactをimportしないでいい
これはuserが書いているtranspile前のコードの話をしている
data:image/s3,"s3://crabby-images/6909e/6909e479c8a80b7a95155552c64ee71be78e5662" alt="mrsekut mrsekut"
typescriptを使っている時