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
jQueryからElmまで
Search
Seiya IZUMI
June 01, 2019
Programming
1
1.6k
jQueryからElmまで
Seiya IZUMI
June 01, 2019
Tweet
Share
More Decks by Seiya IZUMI
See All by Seiya IZUMI
Node.jsの宣言的マイグレーションツール作った
izumisy
0
16
TailorにおけるSchema-driven UIの実践例
izumisy
0
370
Elm, the functional frontend
izumisy
3
1.1k
Elmの歩き方2019
izumisy
5
3.4k
Our Journey with the Biggest Elm App in Japan
izumisy
0
170
Ordering and Ordered
izumisy
1
100
Choo: Fun Functional Framework
izumisy
1
510
StackoverflowでREPを稼ぐ技術
izumisy
1
830
フロントエンド・バリデーション
izumisy
5
3.6k
Other Decks in Programming
See All in Programming
[FEConf 2025] 모노레포 절망편, 14개 레포로 부활하기까지 걸린 1년
mmmaxkim
0
1.6k
go test -json そして testing.T.Attr / Kyoto.go #63
utgwkk
3
290
TDD 実践ミニトーク
contour_gara
1
290
時間軸から考えるTerraformを使う理由と留意点
fufuhu
15
4.7k
AIと私たちの学習の変化を考える - Claude Codeの学習モードを例に
azukiazusa1
10
3.8k
GitHubとGitLabとAWS CodePipelineでCI/CDを組み比べてみた
satoshi256kbyte
4
220
AWS発のAIエディタKiroを使ってみた
iriikeita
1
180
「手軽で便利」に潜む罠。 Popover API を WCAG 2.2の視点で安全に使うには
taitotnk
0
840
知っているようで知らない"rails new"の世界 / The World of "rails new" You Think You Know but Don't
luccafort
PRO
1
110
How Android Uses Data Structures Behind The Scenes
l2hyunwoo
0
420
ユーザーも開発者も悩ませない TV アプリ開発 ~Compose の内部実装から学ぶフォーカス制御~
taked137
0
150
Namespace and Its Future
tagomoris
6
700
Featured
See All Featured
Build your cross-platform service in a week with App Engine
jlugia
231
18k
Reflections from 52 weeks, 52 projects
jeffersonlam
352
21k
Cheating the UX When There Is Nothing More to Optimize - PixelPioneers
stephaniewalter
285
13k
個人開発の失敗を避けるイケてる考え方 / tips for indie hackers
panda_program
112
20k
The Language of Interfaces
destraynor
161
25k
Facilitating Awesome Meetings
lara
55
6.5k
A Tale of Four Properties
chriscoyier
160
23k
XXLCSS - How to scale CSS and keep your sanity
sugarenia
248
1.3M
Thoughts on Productivity
jonyablonski
70
4.8k
Evolution of real-time – Irina Nazarova, EuRuKo, 2024
irinanazarova
8
920
Embracing the Ebb and Flow
colly
87
4.8k
Let's Do A Bunch of Simple Stuff to Make Websites Faster
chriscoyier
507
140k
Transcript
jQueryからElmまで Seiya Izumi
自己紹介 ❏ Fringe81 Web Engineer ❏ Scala, Golang を書いていましたが 現在は
Elm を書いています ❏ Elm Europe 2019 に登壇予定(6月末)
このスライドの目的 自分なりのフロントエンドの学びを これまでの歩みと一緒に共有したい! ついでにElmを紹介したい!
僕とフロントエンド
僕とフロントエンド
僕とフロントエンド
僕とフロントエンド
僕とフロントエンド
僕とフロントエンド
初めて作ったウェブアプリケーションぽいもの
TabStockerの機能 • ローカルで保存 • 同期して保存 をそれぞれスイッチできる 並び替えができる
HTMLレンダリングを手で • setAttributeとcreateElementを駆 使してDOM操作全て手書き • タブスイッチもインラインスタイル の操作で実装
HTMLレンダリングを手で • setAttributeとcreateElementを駆 使してDOM操作全て手書き • タブスイッチもインラインスタイル の操作で実装 しんどい!!
DOM操作は人間には複雑すぎた • 粘ってSPAのようなものを作ろうとするとすぐ地獄が始まる • 自前でインクリメンタルサーチやインフィニット・ローディングを作るツラさ • XSSなどのセキュリティ事故にも繋がる危険性あり
人間が手でDOMを書く時代は終わり
状態と画面の分離 • アプリケーションのロジックによる結果を “状態” として画面とは分離して表現 ◦ ロジックの影響範囲を限定することでテスタブルに ◦ DOMのレンダリングがフレームワークによって行われるようになり安全 ◦
複雑な画面の構築も比較的ラクにできるためアプリケーションの大規模化へ
状態と画面の分離 { value: 10 } <div class=”value-box”> <div>Value is {{value}}</div>
</div> Scope HTML Value is 10 ロジックによる計算の結果は Scope(状態)のみに影響を与える
状態と画面の分離 { value: 10 } <div class=”value-box”> <div>Value is {{value}}</div>
</div> Scope HTML Value is 10 HTMLはどのように画面を作るかを表現するだけ(画面)
状態と画面の分離 { value: calc(2) } <div class=”value-box”> <div>Value is {{value}}</div>
</div> Scope HTML Value is 22 function calc(n) { return (n * 10 + 2) }
状態と画面の分離 { value: calc(2) } <div class=”value-box”> <div>Value is {{value}}</div>
</div> Scope HTML Value is 22 function calc(n) { return (n * 10 + 2) } Scopeの依存する ビジネスロジック のみをテストする だけで挙動が担保 できる
状態と画面の分離 { value: calc(2) } <div class=”value-box”> <div>Value is {{value}}</div>
</div> Scope HTML Value is 22 function calc(n) { return (n * 10 + 2) } Scopeの依存する ビジネスロジック のみをテストする だけで挙動が担保 できる 画面はビジネスロジックによる影響を受けない
大規模化するフロントエンドの苦しみ Component
大規模化するフロントエンドの苦しみ Component Component Component
大規模化するフロントエンドの苦しみ Component Component Component Component Component
大規模化するフロントエンドの苦しみ Component Component Component Component Component A Web API GET
大規模化するフロントエンドの苦しみ Component Component Component Component Component A 画面上はココで表示したい ↑
大規模化するフロントエンドの苦しみ Component Component Component Component Component A
大規模化するフロントエンドの苦しみ Component Component Component Component Component A 親コンポーネントからデータを受け取る口 を各コンポーネントが用意しておかないと いけない
→ Prop Drilling なんで俺がデータ 持たなアカンねん...
大規模化するフロントエンドの苦しみ Component Component Component Component Component Event Emitter
大規模化するフロントエンドの苦しみ Component Component Component Component Component Event Emitter A ↑画面上はココで表示したい
大規模化するフロントエンドの苦しみ Component Component Component Component Component Event Emitter Subscribe Emit
A
大規模化するフロントエンドの苦しみ Component Component Component Component Component Event Emitter Subscribe Emit
A
大規模化するフロントエンドの苦しみ Component Component Component Component Component Event Emitter Subscribe Emit
Event Emitter Subscribe Emit
大規模化するフロントエンドの苦しみ Component Component Component Component Component Event Emitter Subscribe Emit
Event Emitter Event Emitter Subscribe Emit Subscribe Subscribe Emit Subscribe データの交換のためだけにイベントシステムが 使われる → イベント・エミッタ地獄
フロントエンドの地獄とはなんだったのか ❖ “状態” と “画面” は分離されたものの、今度は状態の爆発がアプリケーショ ンの課題へ ❖ イベント発火が数珠つなぎになっていて、状態がどのように変化するかは、 動かしてみないと分からない
フロントエンドの地獄とはなんだったのか ❖ “状態” と “画面” は分離されたものの、今度は状態の爆発がアプリケーショ ンの課題へ ❖ イベント発火が数珠つなぎになっていて、状態がどのように変化するかは、 動かしてみないと分からない
➢ アプリケーションが予測不可能
Fluxアーキテクチャの発見
Fluxアーキテクチャの発見 Fluxのユニフローは関数として表現できる
関数と予測可能性 N + 10 + V 10 33 なんらかの外部要因 によって変化するV
依存
関数と予測可能性 10 33 なんらかの外部要因 によって変化するV 依存 ↑この依存が増えれば増えるほど、予測不可能性が増大する N + 10
+ V
関数と予測可能性 N + 10 10 20 純粋関数は予測可能性が高い
関数型表現がフロントエンドにもたらすもの ❏ アプリケーションを純粋な関数で構成することによって 予測可能性(参照透過性)を高めることができる ❏ コンポーネントに想定外の依存を持たせないことで 意外性を少なくする
他フレームワークの趨勢 React • Class コンポーネントよりも Functional コンポーネント推し • コンポーネント・ライフサイクルなどの個別の状態表現APIを順次廃止 Vue.js
• 長らく期待されていたクラスAPIのプロポーザルを却下 • React Hooks インスパイアな関数コンポジションによるコンポーネント定義にシフト
フロントエンドと関数型アプローチ
大まかなElmの特徴 • 全ての変数がイミュータブル • 状態更新、ビューなどをすべて関数として扱う • アプリケーションのアーキテクチャが 決まっている(TEA) • Reduxの設計に影響を与えた
JSにおける “ミュータブル” な状態表現の例 var status = { value: 10 };
status.value += 5; status.value++; console.log(status.value) // 16
イミュータブルな状態更新 SET_VALUE: 5 PLUS_VALUE: 3 PLUS_VALUE: 3 MINUS_VALUE: 2 イベント
状態 5 + 3 + 3 - 2 = 9 最新の状態というのは変更(イベント)の積 み上げから計算(畳み込み)されたものにな る { value: 9 }
イミュータブルな状態更新 SET_VALUE: 5 PLUS_VALUE: 3 PLUS_VALUE: 3 MINUS_VALUE: 2 イベント
状態 最新の状態というのは変更(イベント)の積 み上げから計算(畳み込み)されたものにな る { value: 9 } <div> <div>Value is 9</div> </div> ビューもまた状態から HTMLをつくる関 数として表現できる
TEA (The Elm Architecture) View Model Update レンダリング メッセージ 更新
アプリケーションの状態は 常にModelが表す ModelからHTML を計算する アプリケーションの 次の状態を計算する
TEA (The Elm Architecture) View Model Update レンダリング メッセージ 更新
• イミュータビリティと関数型表現を前提としたアプリケーション・ アーキテクチャ • 大規模なアプリケーションを作る上での意外性を排除することで、 データ構造やビジネスロジックの設計に注力できる
フロントエンドは関数 SET_VALUE: 5 Web API ユーザーの操 作 etc... HTML PLUS_VALUE:
3 PLUS_VALUE: 3 MINUS_VALUE: 2
まとめ: 僕から見たフロントエンドの進化
まとめ: 僕から見たフロントエンドの進化 アーキテクチャ上のルールと 制約の進化
まとめ: 僕から見たフロントエンドの進化 • フロントエンド・アプリケーションの大規模化 • Fluxアーキテクチャや関数型アプローチなどの、見方を変えればアプリケーションを 安全に作るための「レール」のようなものが登場 • 自由とスケーラビリティは二律背反(何を捨てて、何に大事にするか)
あなたにとってのフロントエンドの進化はどんなものでしたか? ぜひ、懇親会で教えて下さい
以上!