Slide 1

Slide 1 text

モダンJSフレームワークの ビルドプロセス なぜReactは503行、Svelteは12行なのか フロントエンド テックリード Maple

Slide 2

Slide 2 text

登壇者紹介 Name Maple Carrier 株式会社SODA Hobby Comment ピアノ、アニメ オフライン登壇初めてです。 2

Slide 3

Slide 3 text

Agenda 1. 実測値 2. 抽象化アーキテクチャ 3. Svelteのコンパイル戦略 4. React Compilerと未来予想 3

Slide 4

Slide 4 text

実測値 同じボタンコンポーネントが503行 , 12行になる現実 1. 4

Slide 5

Slide 5 text

Version Bundler Build Command React 19.1.1 esbuild 0.19.0 esbuild --bundle --minify --format=esm React Version Bundler Build Command Svelte 5.0.0 Vite 5.0.0 vite build --minify Svelte ビルド環境情報 5

Slide 6

Slide 6 text

ビルド前ソースコード 1 2 3 4 5 6 7 8 9 10 11 import from export default function const return button button { useState } ; () { [count, setCount] ( ); ( < onClick={() (count )}> Count: {count} ); } 'react' Counter useState setCount = => + 0 1 1 2 3 4 5 6 7 < > let count = 0; < on:click={() count }> Count: {count} script script button button => ++ React Svelte 6

Slide 7

Slide 7 text

ほぼ同じコード... しかし、ビルドすると? 7

Slide 8

Slide 8 text

ビルド後ソースコード 1 2 3 4 5 6 7 8 9 var var var var var var var function return __create Object.create; __defProp Object.defineProperty; __getOwnPropDesc Object.getOwnPropertyDescriptor; __getOwnPropNames Object.getOwnPropertyNames; __getProtoOf Object.getPrototypeOf; __hasOwnProp Object.prototype.hasOwnProperty; (cb, mod) () { mod ( , cb[ (cb)[ ]])((mod { exports {} }).exports, mod), mod.exports; }; = = = = = = = => || = : __commonJS __require __getOwnPropNames 0 0 1 2 3 4 5 6 7 8 9 10 11 12 13 import as from var export default function let var var $ ; root $. ( ); ($anchor) { count $. ( ); button (); text $. (button); $. (() $. (text, ${$. (count) } )); $. ( , button, () $. (count)); $. ($anchor, button); } * = = = = => ?? => 'svelte/internal/client' ` ` `Count: '' ` 'click' template Button state root child template_effect set_text get event update append 0 React 503行 Svelte 12行 8

Slide 9

Slide 9 text

同じUIなのに、 なぜこれほど違うのか? 9

Slide 10

Slide 10 text

この謎を解明するため、 ビルドプロセスを詳しく 見ていきましょう 10

Slide 11

Slide 11 text

抽象化アーキテクチャ なぜ503行が必要なのか - 5つの抽象化層の詳細 2. 11

Slide 12

Slide 12 text

第1層:Component Foundation System createElement, Component基盤、 共通ユーティリティ 第2層:JSX Transformation System JSX変換、動的コンポーネント生成、 Props管理 第3層:UI Update Optimization System UI最適化 第5層:State Management System 状態管理、副作用処理、ライフサイクル 抽象化 第4層:Rendering Control System レンダリング制御 抽象化アーキテクチャ概要 12 ※これは私がReactのビルド後コードを理解しやすくするために整理した独自の分類です

Slide 13

Slide 13 text

第1層: Component Foundation System 目標 コンポーネントの基盤処理 を実現する 13

Slide 14

Slide 14 text

createElement: JSX→Virtual DOM Component基底クラス 開発時型チェック Context API基盤 実行時に必要な処理 React ランタイムで処理 コンパイル時で処理 テンプレート→直接DOMコード コンポーネントコンパイル TypeScript統合型チェック 自動依存追跡 同じ目標を異なる戦略で達成 Svelte VS 14

Slide 15

Slide 15 text

第2層: JSX Transformation System 目標 JSX/テンプレートをDOMに 変換する 15

Slide 16

Slide 16 text

JSX→createElement変換 動的コンポーネント生成 Props管理と検証 実行時に必要な処理 React ランタイムで処理 コンパイル時で処理 テンプレート→DOM変換 静的コンポーネント解析 TypeScript統合型システム 同じ目標を異なる戦略で達成 Svelte VS 16

Slide 17

Slide 17 text

第3層: UI Update Optimization System 目標 UI更新を最適化して実行する 17

Slide 18

Slide 18 text

実行時に必要な処理 仮想DOM表現生成 Diffアルゴリズム 最小限DOM操作 React ランタイムで処理 コンパイル時で処理 コンパイル時更新解析 自動依存追跡 直接DOM操作コード生成 ゼロオーバーヘッド 同じ目標を異なる戦略で達成 Svelte VS 18

Slide 19

Slide 19 text

第4層: Rendering Control System 目標 レンダリングのパフォーマンス を制御する 19

Slide 20

Slide 20 text

実行時に必要な処理 中断可能レンダリング Lanes優先度管理 Fiber仮想スタック Concurrent機能 React ランタイムで処理 コンパイル時で処理 シンプルな同期更新 tick()で手動制御 直接実行 予測可能なパフォーマンス 同じ目標を異なる戦略で達成 Svelte VS 20

Slide 21

Slide 21 text

第5層: State Management System 目標 状態管理とリアクティブ 更新を実現 21

Slide 22

Slide 22 text

実行時に必要な処理 useState, useReducer useEffect 副作用制御 useMemo, useCallback カスタムHooks React ランタイムで処理 コンパイル時で処理 ネイティブlet/const $: リアクティブ文 自動依存追跡 JavaScript関数 同じ目標を異なる戦略で達成 Svelte VS 22

Slide 23

Slide 23 text

異なる戦略で同じ目標を達成 23

Slide 24

Slide 24 text

Svelteのコンパイル戦略 3. 12行を実現するコンパイル時処理 24

Slide 25

Slide 25 text

抽象化層をすべて削除する Component Foundation System JSX Transformation System UI Update Optimization System Rendering Control System State Management System 削除される5層 残る必要最小限の機能 直接DOM操作 イベントハンドラー 状態更新関数 25

Slide 26

Slide 26 text

React Compilerと未来予想 Svelte5 ,React Compiler 4. 27

Slide 27

Slide 27 text

React Compilerのアプローチ VDOMは維持 自動メモ化でVDOM差分処理を最小化 不要な再レンダリングを抑制 useMemo/useCallback/React.memoが不要に ビルド時自動最適化 26

Slide 28

Slide 28 text

私が考えるこれまでの変遷と未来予想 2006-2014 jQuery時代 シンプルなDOM操作API プラグインエコシステムの充実 2015-2018 Virtual DOM時代 React, Vue 2が主流 ランタイム抽象化による開発者体験向上 2019-2024 Svelte, Solid.js 認知拡大 パフォーマンス重視へ回帰 ランタイムオーバーヘッドの削減 2025- ハイブリッド時代 React Compiler 既存フレームワークでコンパイル最適化を採用 28

Slide 29

Slide 29 text

Thank You! 29