Upgrade to Pro
— share decks privately, control downloads, hide ads and more …
Speaker Deck
Features
Speaker Deck
PRO
Sign in
Sign up for free
Search
Search
モダンJSフレームワークのビルドプロセス 〜なぜReactは503行、Svelteは12行なのか〜
Search
Sponsored
·
SiteGround - Reliable hosting with speed, security, and support you can count on.
→
Maple
November 18, 2025
Programming
450
0
Share
Embed
Copy iframe code
Copy JS code
Copy link
Start on current slide
モダンJSフレームワークのビルドプロセス 〜なぜReactは503行、Svelteは12行なのか〜
JSConf 2025
の登壇資料です。
Maple
November 18, 2025
More Decks by Maple
See All by Maple
検索機能リプレイスを4ヶ月→2ヶ月に! AI Agentで実現した2倍速リプレイス
fuuki12
4
1.4k
フロントエンドチームでリアーキテクチャを行っています!
fuuki12
0
320
Other Decks in Programming
See All in Programming
技術記事、 専門家としてのプログラマ、 言語化
mizchi
13
6.3k
Vue × Nuxt × Oxc どこまで使える?実運用の現在地
andpad
0
280
AI 輔助遺留系統現代化的經驗分享
jame2408
1
860
TypeScript+Orvalで実現する型安全かつ堅牢でスケーラブルなマルチチャネル通知基盤 / TSKaigi Night talks ~after conference~
d0riven
0
350
JavaDoc 再入門
nagise
1
370
Javaの型とAI時代に型が大事な理由 / java types and type in AI era
kishida
2
140
その問い、本当に正しいですか?AI時代のエンジニアに必要な哲学と認知科学 / ai-philosophy-cognitive-science
minodriven
11
5.9k
AIを活用したE2Eテスト実装効率化のあゆみ / ebisu-mobile-14-kotetu
kotetuco
0
110
並列実装の現場、2ヶ月間実務でAIを使い倒したAIもPCも私も限界が近い
ming_ayami
0
130
Agentic UI
manfredsteyer
PRO
0
180
The NotImplementedError Problem in Ruby
koic
1
870
Lemonade + Foundry Toolkit でお手軽アプリ開発
seosoft
1
360
Featured
See All Featured
A designer walks into a library…
pauljervisheath
211
24k
Leadership Guide Workshop - DevTernity 2021
reverentgeek
1
310
No one is an island. Learnings from fostering a developers community.
thoeni
21
3.8k
Between Models and Reality
mayunak
4
340
What the history of the web can teach us about the future of AI
inesmontani
PRO
1
620
Max Prin - Stacking Signals: How International SEO Comes Together (And Falls Apart)
techseoconnect
PRO
0
190
Chrome DevTools: State of the Union 2024 - Debugging React & Beyond
addyosmani
10
1.2k
Building the Perfect Custom Keyboard
takai
2
800
RailsConf 2023
tenderlove
30
1.5k
The Curse of the Amulet
leimatthew05
1
13k
How to make the Groovebox
asonas
2
2.2k
Templates, Plugins, & Blocks: Oh My! Creating the theme that thinks of everything
marktimemedia
31
2.8k
Transcript
モダンJSフレームワークの ビルドプロセス なぜReactは503行、Svelteは12行なのか フロントエンド テックリード Maple
登壇者紹介 Name Maple Carrier 株式会社SODA Hobby Comment ピアノ、アニメ オフライン登壇初めてです。 2
Agenda 1. 実測値 2. 抽象化アーキテクチャ 3. Svelteのコンパイル戦略 4. React Compilerと未来予想
3
実測値 同じボタンコンポーネントが503行 , 12行になる現実 1. 4
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
ビルド前ソースコード 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
ほぼ同じコード... しかし、ビルドすると? 7
ビルド後ソースコード 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' `<button> </button>` `Count: '' ` 'click' template Button state root child template_effect set_text get event update append 0 React 503行 Svelte 12行 8
同じUIなのに、 なぜこれほど違うのか? 9
この謎を解明するため、 ビルドプロセスを詳しく 見ていきましょう 10
抽象化アーキテクチャ なぜ503行が必要なのか - 5つの抽象化層の詳細 2. 11
第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のビルド後コードを理解しやすくするために整理した独自の分類です
第1層: Component Foundation System 目標 コンポーネントの基盤処理 を実現する 13
createElement: JSX→Virtual DOM Component基底クラス 開発時型チェック Context API基盤 実行時に必要な処理 React ランタイムで処理
コンパイル時で処理 テンプレート→直接DOMコード コンポーネントコンパイル TypeScript統合型チェック 自動依存追跡 同じ目標を異なる戦略で達成 Svelte VS 14
第2層: JSX Transformation System 目標 JSX/テンプレートをDOMに 変換する 15
JSX→createElement変換 動的コンポーネント生成 Props管理と検証 実行時に必要な処理 React ランタイムで処理 コンパイル時で処理 テンプレート→DOM変換 静的コンポーネント解析 TypeScript統合型システム
同じ目標を異なる戦略で達成 Svelte VS 16
第3層: UI Update Optimization System 目標 UI更新を最適化して実行する 17
実行時に必要な処理 仮想DOM表現生成 Diffアルゴリズム 最小限DOM操作 React ランタイムで処理 コンパイル時で処理 コンパイル時更新解析 自動依存追跡 直接DOM操作コード生成
ゼロオーバーヘッド 同じ目標を異なる戦略で達成 Svelte VS 18
第4層: Rendering Control System 目標 レンダリングのパフォーマンス を制御する 19
実行時に必要な処理 中断可能レンダリング Lanes優先度管理 Fiber仮想スタック Concurrent機能 React ランタイムで処理 コンパイル時で処理 シンプルな同期更新 tick()で手動制御
直接実行 予測可能なパフォーマンス 同じ目標を異なる戦略で達成 Svelte VS 20
第5層: State Management System 目標 状態管理とリアクティブ 更新を実現 21
実行時に必要な処理 useState, useReducer useEffect 副作用制御 useMemo, useCallback カスタムHooks React ランタイムで処理
コンパイル時で処理 ネイティブlet/const $: リアクティブ文 自動依存追跡 JavaScript関数 同じ目標を異なる戦略で達成 Svelte VS 22
異なる戦略で同じ目標を達成 23
Svelteのコンパイル戦略 3. 12行を実現するコンパイル時処理 24
抽象化層をすべて削除する Component Foundation System JSX Transformation System UI Update Optimization
System Rendering Control System State Management System 削除される5層 残る必要最小限の機能 直接DOM操作 イベントハンドラー 状態更新関数 25
React Compilerと未来予想 Svelte5 ,React Compiler 4. 27
React Compilerのアプローチ VDOMは維持 自動メモ化でVDOM差分処理を最小化 不要な再レンダリングを抑制 useMemo/useCallback/React.memoが不要に ビルド時自動最適化 26
私が考えるこれまでの変遷と未来予想 2006-2014 jQuery時代 シンプルなDOM操作API プラグインエコシステムの充実 2015-2018 Virtual DOM時代 React, Vue
2が主流 ランタイム抽象化による開発者体験向上 2019-2024 Svelte, Solid.js 認知拡大 パフォーマンス重視へ回帰 ランタイムオーバーヘッドの削減 2025- ハイブリッド時代 React Compiler 既存フレームワークでコンパイル最適化を採用 28
Thank You! 29