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
React19で状態管理はどう変わるか
Search
ytaisei
August 03, 2024
Technology
2
62
React19で状態管理はどう変わるか
若手エンジニアLT & 交流会にて使用したスライドです
https://devguil.connpass.com/event/321787/
ytaisei
August 03, 2024
Tweet
Share
More Decks by ytaisei
See All by ytaisei
TanStackで効率的なルーティングとデータ取得を実現
ytaisei
7
1.1k
TanStack Routerで型安全かつ効率的なルーティングを実現
ytaisei
4
1.4k
BunがCommonJSをサポートする理由
ytaisei
2
210
TanStack Router SPA開発の選択肢になるか(+TanStack Query)
ytaisei
2
1.1k
【2023】SWR vs TanStack Query
ytaisei
1
1.8k
React Queryは非同期の状態管理ライブラリだ
ytaisei
3
1.7k
アウトプットが与える影響 〜価値を最大化するための学習サイクル〜
ytaisei
2
1.8k
OpenAPIコード生成ライブラリを 『Orval』に移行した理由
ytaisei
1
3.6k
Other Decks in Technology
See All in Technology
AWSコンテナ本出版から3年経った今、もし改めて執筆し直すなら / If I revise our container book
iselegant
13
3.8k
【若手エンジニア応援LT会】AWSで繋がり、共に成長! ~コミュニティ活動と新人教育への挑戦~
kazushi_ohata
0
150
Product Engineer Night #6プロダクトエンジニアを育む仕組み・施策
hacomono
PRO
1
400
pandasはPolarsに性能面で追いつき追い越せるのか
vaaaaanquish
4
3.2k
新卒1年目が挑む!生成AI × マルチエージェントで実現する次世代オンボーディング / operation-ai-onboarding
cyberagentdevelopers
PRO
1
150
AIを駆使したゲーム開発戦略: 新設AI組織の取り組み / sge-ai-strategy
cyberagentdevelopers
PRO
1
120
ネット広告に未来はあるか?「3rd Party Cookie廃止とPrivacy Sandboxの効果検証の裏側」 / third-party-cookie-privacy
cyberagentdevelopers
PRO
1
120
なんで、私がAWS Heroに!? 〜社外の広い世界に一歩踏み出そう〜
minorun365
PRO
6
1k
CyberAgent 生成AI Deep Dive with Amazon Web Services / genai-aws
cyberagentdevelopers
PRO
1
460
LeSSに潜む「隠れWF病」とその処方箋
lycorptech_jp
PRO
2
110
最速最小からはじめるデータプロダクト / Data Product MVP
amaotone
5
710
Apple/Google/Amazonの決済システムの違いを踏まえた定期購読課金システムの構築 / abema-billing-system
cyberagentdevelopers
PRO
1
210
Featured
See All Featured
Let's Do A Bunch of Simple Stuff to Make Websites Faster
chriscoyier
504
140k
YesSQL, Process and Tooling at Scale
rocio
167
14k
How to train your dragon (web standard)
notwaldorf
88
5.7k
GraphQLとの向き合い方2022年版
quramy
43
13k
Being A Developer After 40
akosma
86
590k
Thoughts on Productivity
jonyablonski
67
4.3k
Refactoring Trust on Your Teams (GOTO; Chicago 2020)
rmw
31
2.6k
Adopting Sorbet at Scale
ufuk
73
9k
[Rails World 2023 - Day 1 Closing Keynote] - The Magic of Rails
eileencodes
32
1.8k
How To Stay Up To Date on Web Technology
chriscoyier
788
250k
Scaling GitHub
holman
458
140k
Helping Users Find Their Own Way: Creating Modern Search Experiences
danielanewman
29
2.2k
Transcript
React19で状態管理はどう変わるか 株式会社AI Shift 安井大晟(ytaisei_)
自己紹介 • 株式会社AI Shift ◦ Webフロントエンド ◦ LLMを活用した新規事業 • 社会人1年目
• 2社でBtoBアプリケーション開発 • Zennで記事をよく書いてる、など
アジェンダ 1. use API 2. useActionState Hook 3. useOptimistic Hook
4. まとめ
アジェンダ 1. use API 2. useActionState Hook 3. useOptimistic Hook
4. まとめ 重要:今回はクライアントでの実行にFocusしています。
use API > use はプロミス (Promise) やコンテクストなどのリソースから 値を読み取るための React API
です。 > プロミスを引数にして呼び出した場合、 use API は Suspense や エラーバウンダリ (error boundary) と協調して動作します。 参考:https://ja.react.dev/reference/react/use
use API > use はプロミス (Promise) やコンテクストなどのリソースから 値を読み取るための React API
です。 > プロミスを引数にして呼び出した場合、 use API は Suspense や エラーバウンダリ (error boundary) と協調して動作します。 参考:https://ja.react.dev/reference/react/use おっ?
ReactのAPIでSuspense for Data Fetchingが可能??? (今までは) TanStack QueryやSWRなどのライブラリを 使用しないと実現できなかった (期待) Reactの標準APIで
Suspense for Data Fetchingを実装したい...
ReactのAPIでSuspense for Data Fetchingが可能??? (今までは) TanStack QueryやSWRなどのライブラリを 使用しないと実現できなかった (期待) Reactの標準APIで
Suspense for Data Fetchingを実装したい... 非推奨 😢
Promiseのキャッシュが必要 何も工夫をしないとレンダリングのたびに Promiseが再生成されてしまう 不必要に非同期処理が走る 自前でキャッシュを用意する...?
非同期の状態管理ライブラリは Promiseのキャッシュと その制御という観点で未だ重要な役割を持つ
コンテクストから値を読み取る • use APIにコンテキストを渡すと useContextと同じ挙動になる • useContextとの違い ◦ 条件分岐の中で使用できる
コンテクストから値を読み取る • use APIにコンテキストを渡すと useContextと同じ挙動になる • useContextとの違い ◦ 条件分岐の中で使用できる use
はより柔軟であるため、 useContext よりも優先的に使用する 参考:https://ja.react.dev/reference/react/use#reading-context-with-use
useActionState Hook 状態の更新に伴う要素 • 更新する状態 • 更新中の状態 • 更新結果の状態 Stateで実装するのはしんどい...
→ Formライブラリを採用する動機になる (React19以前のコード)
useActionState Hook 状態の更新に伴う要素 • 更新する状態 ◦ formの拡張(FormData) • 更新中の状態 ◦
isPending • 更新結果の状態 ◦ Success or Error State これらがReactのHooksで完結する
useActionStateとformの拡張によって、 状態の更新を効率的に管理できるようになった。 • バンドルサイズの軽減 • 学習コストの低下 • ライブラリのメンテナンス これらの観点からも Reactで状態の更新が完結するのはメリットがある。
useOptimistic Hook 個人的に最も期待している Hookです
useOptimistic Hook 楽観的更新とは? 非同期リクエストの進行中、最終的に得るはずの状 態を先に楽観的に表示しておくというもの
これまでの楽観的更新 React19以前(TanStack Queryの例) TanStack Queryでの処理 1. 実行中のクエリをキャンセル 2. 更新前のスナップショットを記憶 3.
キャッシュを直接更新&描画 4. 非同期で更新処理を実行 5. 成功した場合はinvalidateQueriesで データを再取得 6. エラーの場合は表示中の状態を Fallback
これまでの楽観的更新 やりたいことの割に処理が複雑 ... • ライブラリ固有の知識が必要 ◦ キャッシュの扱い ◦ Callback関数の実行順序 etc.
• ライブラリによって若干実装が変わる useOptimisticが解決
useOptimisticによる楽観的更新 useOptimisticでの処理 1. useOptimisticに初期値を渡す 2. useOptimisticから返される dispatch関数を更新処理の前に実行 a. stateが更新&描画 3.
非同期処理が成功・失敗に合わせて処 理を追加
ライブラリ固有の学習無しに楽観的更新を実装可能になった
まとめ • useはコンテキストからのリソース取得が柔軟 • useActionStateとuseOptimisticによって 今までライブラリに頼っていた実装が React固有のAPI・Hooksによって実現できる ◦ まずはReactの機能で実装を試みて、 足りない要素を補うようにより薄くライブラリを使っていく意識