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
5分でわかるPreactのVDOMで作るWebエディタ
Search
did0es
June 25, 2024
Technology
0
240
5分でわかるPreactのVDOMで作るWebエディタ
めぐろLT #16 (
https://meguro-lt.connpass.com/event/316885
)にて発表した LT の資料です。
紹介したライブラリのデモは
こちら
です。
did0es
June 25, 2024
Tweet
Share
More Decks by did0es
See All by did0es
うわっ...私のSwagger、古すぎ...?grpc-gateway向けのSwaggerと向き合う
shuta13
0
120
ViteとTypeScriptのProject Referencesで 大規模モノレポのUIカタログのリリースサイクルを高速化する
shuta13
3
330
歴代のWeb Speed Hackathonの出題から考えるデグレしないパフォーマンス改善
shuta13
8
820
なぜクラウドサービスで Web コンソールを提供するのか
shuta13
4
2.4k
TailwindCSSでUIライブラリを作る際のハマりどころ
shuta13
0
780
codemodとうまく付き合うには
shuta13
0
2.9k
プライベートクラウドのコンソール画面をNext.jsのApp Routerでフルリプレイスした話
shuta13
4
980
CyberAgent Developer Conference(CADC) 2023 LP開発の舞台裏
shuta13
0
290
Turborepo Code Generationによる、サイバーエージェントグループのフロントエンド開発の効率化
shuta13
5
2.7k
Other Decks in Technology
See All in Technology
ガバメントクラウドにおけるAWSの長期継続割引について
takeda_h
2
5.3k
TypeScript 7.0の現在地と備え方
uhyo
7
1.8k
20260321_エンベディングってなに?RAGってなに?エンベディングの説明とGemini Embedding 2 の紹介
tsho
0
100
システム標準化PMOから ガバメントクラウドCoEへ
techniczna
1
140
スケールアップ企業でQA組織が機能し続けるための組織設計と仕組み〜ボトムアップとトップダウンを両輪としたアプローチ〜
tarappo
1
170
脳内メモリ、思ったより揮発性だった
koutorino
0
380
コンテキスト・ハーネスエンジニアリングの現在
hirosatogamo
PRO
4
500
20260311 ビジネスSWG活動報告(デジタルアイデンティティ人材育成推進WG Ph2 活動報告会)
oidfj
0
350
2026-03-11 JAWS-UG 茨城 #12 改めてALBを便利に使う
masasuzu
2
400
会社紹介資料 / Sansan Company Profile
sansan33
PRO
16
410k
VLAモデル構築のための AIロボット向け模倣学習キット
kmatsuiugo
0
260
Zeal of the Convert: Taming Shai-Hulud with AI
ramimac
0
150
Featured
See All Featured
Faster Mobile Websites
deanohume
310
31k
Noah Learner - AI + Me: how we built a GSC Bulk Export data pipeline
techseoconnect
PRO
0
140
ピンチをチャンスに:未来をつくるプロダクトロードマップ #pmconf2020
aki_iinuma
128
55k
New Earth Scene 8
popppiees
1
1.7k
ラッコキーワード サービス紹介資料
rakko
1
2.7M
Refactoring Trust on Your Teams (GOTO; Chicago 2020)
rmw
35
3.4k
Mind Mapping
helmedeiros
PRO
1
130
Highjacked: Video Game Concept Design
rkendrick25
PRO
1
320
Unlocking the hidden potential of vector embeddings in international SEO
frankvandijk
0
200
The Organizational Zoo: Understanding Human Behavior Agility Through Metaphoric Constructive Conversations (based on the works of Arthur Shelley, Ph.D)
kimpetersen
PRO
0
270
Visualizing Your Data: Incorporating Mongo into Loggly Infrastructure
mongodb
49
9.9k
How to Create Impact in a Changing Tech Landscape [PerfNow 2023]
tammyeverts
55
3.3k
Transcript
5分でわかる PreactのVDOMで作る Webエディタ did0es 2024/06/25 @ めぐろLT #16
did0es(Hirai Shuta) SWE @ CyberAgent, Inc. Main organizer @ Meguro.es
最近の供養したいこと: EURO2024 をリアタイ観戦して サッカー意識を高めていたところ 寝不足で怪我をしてしまい まさかの自分が負傷退場する羽目に 自己紹介
タイトル再掲 5分でわかる PreactのVDOMで作る Webエディタ
🤖 < エディタライブラリを使えば 5分もかからないのに...
車輪の再発明した結果 車輪ではないものを創り出してしまった お話です😇
背景 lexical(https://lexical.dev) を使いたかった ・Draft.js(https://draftjs.org)の後継 ・当時(2,3年前)はα版でdocsがスカスカだった α版を本番運用はできないので自作した ・メディアサイトの入稿画面を作る仕事の一貫 ・Reconciler を搭載したエディタライブラリを作れば それはもう
lexical では!?という安直な考え
エディタの要件 リッチ ・非エンジニアが使えるように ・DnDやGUIによるブロック操作は必須 特定のViewライブラリ非依存 ・React以外に、VueやWeb Componentsで組まれている箇所などでも 使えるように
どうやって何を作ったのか
実装フロー 1. lexical の実装を読む 2. React の技術の転用だと気づき、React の実装を読む 3. lexical,
React の規模では再現できないと思い、よりミニマルな Preact の実装を読む 4. Preact から Reconciler を取り出す 5. Reconciler を好きなエディタライブラリに移植する 6. lexical かな それって lexical だね 差分検出大好き(完成🐲)
lexical の仕組みを簡単に 画像: https://dio.la/article/lexical-state-updates
🤖 < lexical の実装を 真似すればよかったのに...
人間は怠惰なので つい楽をしようとしてしまう
せや! 昔 React の中身を読んだことあったから その知識でどうにかしたろ!
lexical と似ている React を読んでみる https://github.com/facebook/react の Reconciler を中心に読みつつ、量が膨大 なので 以下の参考資料と併せて読んでいく
・https://ja.legacy.reactjs.org/docs/implementation-notes.html ・旧型の差分検出(Stack)の話 ・https://jsconf.jp/2022/talk/internal-implementation-of-react ・新型の差分検出(Fiber)の話 ・https://github.com/shuta13/react-deep-dive(注: 手前味噌) ・Stack, Fiber 両方を再現する話
lexical より複雑では
Preact を読んでみる React の軽量版で、なんとコードは1000行程度(3年前の情報) https://github.com/preactjs/preact を読みつつ、適宜以下も参考に ・https://blog.ojisan.io/preact-reading ・差分検出処理についてかなり詳細に書かれている記事 ・preactの仕組みを理解する軽量版教育用preactを作ってる話 -
Speaker Deck ・上の記事と同じ方がフルスクラッチで再現した話
Preact から Reconciler を取り出す preact/src/diff 配下の実装から、VDOM を比較・更新している処理だけを 取り出して動かす ・Preact は可読性よりも
Perf を意識したコードになっているので 人間に優しいように、適宜処理の流れや変数名を書き換え ・そもそも元の実装は Pure JS なので TypeScript で書き換え
余談: react-reconciler をインストールすれば解決? react-reconciler というパッケージが React から独立して存在する ・これをインストールすれば差分検出できそう... ・しかし peerDeps
に React が入っているのでスタンドアロンでは動かない ちなみに Preact は、reconciler などを個別にパッケージ化しない方針 ・react-three-fiber on Preact? (discussion) · Issue #2538
エディタライブラリへ移植 View ライブラリ非依存のエディタライブラリの選定 ・選ばれたのは Editor.js でした Editor.js ハック ・また内部実装を持ってくるわけにはいかないので プラグインとして、Reconciler
を入れる ・プラグインを選択すると VDOM からブロックが生成される ・ブロックごとに state を持つ ・もはや lexical とは別物に...
デモ(時間あれば)
作ってみてどうだった?
よかった点 思いついたことを具現化できた ・アウトプット◯ ・発想△ lexical, React, Preactの実装に詳しくなった ・特に Preact を完全に理解した
・VDOM から如何にして DOM を組み立てるのか ・何の差分をどうやって検出するのか
苦労した点 Preact の hooks 周辺 ・内部状態を扱う箇所が副作用多めで難解 ・useState を中心に、自分が再現できるものだけ再現 型 ・元の実装は
Pure JS だったので TS 化したが、工数が膨れ上がった だけだった ・一部で型の恩恵を得られたが ts-expect-error まみれ ・Preact の処理をほぼそのまま動かせたのでテスト書くだけで十分だった
反省点 あまりにもオーバーエンジニアリング ・ラーメンを作るためにまず小麦を育てている状態 バグが生まれ続けた ・見事なマッチポンプが出来上がった ・この反省から別のライブラリを拡張した テストも元の実装から持ってくるべき ・今流行りのGoやRustによる置き換えはこれをやっている
https://github.com/cam-inc/pde.js (inactive) お賽銭代わりに良ければスターをポチッとお願いします😭
供養完了(?)
ご清聴 ありがとうございました!