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
React Queryは非同期の状態管理ライブラリだ
Search
Sponsored
·
Ship Features Fearlessly
Turn features on and off without deploys. Used by thousands of Ruby developers.
→
ytaisei
July 13, 2023
Technology
3
2.1k
React Queryは非同期の状態管理ライブラリだ
HRBrain Fly High #4 -Frontend-にて使用した資料
ytaisei
July 13, 2023
Tweet
Share
More Decks by ytaisei
See All by ytaisei
TanStack Routerを新規プロダクトで1年間運用してみた結果
ytaisei
1
250
Reactを段階的に覗いてみる
ytaisei
3
2k
Reactのトランジションを覗いてみる
ytaisei
1
2.6k
Deep Dive Into React 〜React Fiber Architectureについて〜
ytaisei
2
470
React19で状態管理はどう変わるか
ytaisei
2
200
TanStackで効率的なルーティングとデータ取得を実現
ytaisei
10
2.5k
TanStack Routerで型安全かつ効率的なルーティングを実現
ytaisei
4
2.4k
BunがCommonJSをサポートする理由
ytaisei
2
460
TanStack Router SPA開発の選択肢になるか(+TanStack Query)
ytaisei
2
1.7k
Other Decks in Technology
See All in Technology
[2026-03-07]あの日諦めたスクラムの答えを僕達はまだ探している。〜守ることと、諦めることと、それでも前に進むチームの話〜
tosite
0
140
S3はフラットである –AWS公式SDKにも存在した、 署名付きURLにおけるパストラバーサル脆弱性– / JAWS DAYS 2026
flatt_security
0
1.7k
AWS DevOps Agent vs SRE俺 / AWS DevOps Agent vs me, the SRE
sms_tech
3
530
Oracle Database@Azure:サービス概要のご紹介
oracle4engineer
PRO
4
1.2k
モブプログラミング再入門 ー 基本から見直す、AI時代のチーム開発の選択肢 ー / A Re-introduction of Mob Programming
takaking22
5
1.2k
メタデータ同期に潜んでいた問題 〜 Cache Stampede 時の Cycle Wait を⾒つけた話
lycorptech_jp
PRO
0
160
[JAWS DAYS 2026]私の AWS DevOps Agent 推しポイント
furuton
0
140
Claude Code Skills 勉強会 (DevelersIO向けに調整済み) / claude code skills for devio
masahirokawahara
1
13k
When an innocent-looking ListOffsets Call Took Down Our Kafka Cluster
lycorptech_jp
PRO
0
120
Shifting from MCP to Skills / ベストプラクティスの変遷を辿る
yamanoku
4
770
Oracle Database@AWS:サービス概要のご紹介
oracle4engineer
PRO
3
1.7k
IBM Bobを使って、PostgreSQLのToDoアプリをDb2へ変換してみよう/202603_Dojo_Bob
mayumihirano
1
300
Featured
See All Featured
CSS Pre-Processors: Stylus, Less & Sass
bermonpainter
360
30k
The Organizational Zoo: Understanding Human Behavior Agility Through Metaphoric Constructive Conversations (based on the works of Arthur Shelley, Ph.D)
kimpetersen
PRO
0
270
The Cost Of JavaScript in 2023
addyosmani
55
9.8k
B2B Lead Gen: Tactics, Traps & Triumph
marketingsoph
0
74
I Don’t Have Time: Getting Over the Fear to Launch Your Podcast
jcasabona
34
2.7k
Keith and Marios Guide to Fast Websites
keithpitt
413
23k
Measuring & Analyzing Core Web Vitals
bluesmoon
9
780
個人開発の失敗を避けるイケてる考え方 / tips for indie hackers
panda_program
122
21k
Easily Structure & Communicate Ideas using Wireframe
afnizarnur
194
17k
The Art of Delivering Value - GDevCon NA Keynote
reverentgeek
16
1.9k
Stop Working from a Prison Cell
hatefulcrawdad
274
21k
Test your architecture with Archunit
thirion
1
2.2k
Transcript
React Queryは非同期の 状態管理ライブラリだ HRBrain 長期インターン 安井大晟
自己紹介 01. 02. 03. 04. 05. 状態管理の種類 Client State vs
Server State 非同期の状態を 管理する キャッシュを 管理する Table of contents
自己紹介 01.
経歴 2019年 早稲田大学教育学部入学 2021年 42Tokyo入学 プログラミングを始める 2022年 技育展優秀賞 2022年 HRBrain長期インターン開始 2023年 春のJavaScript祭りLT登壇 2023年 社内Qiita Engineer Festa運営中
02. 状態管理の種類
Reactの状態には 何種類ある? Redux Context API Recoil jotai useState React Query
SWR
A. 3種類
株式会社ナレッジワークよしこさんの 記事をお借りします
Client State Global State Server State Reactの状態には3種類ある 各Component内で 管理される状態 ページをまたいで
保持し続ける 必要のある状態 サーバーデータ のキャッシュ
Client State Global State Server State Reactの状態には3種類ある UIの状態 トースト表示 APIレスポンス
Client State Global State Server State Reactの状態には3種類ある UIの状態 トースト表示 APIレスポンス
クライアントの状態 サーバーの状態
本来、サーバーの状態は クライアントの状態と 分けて管理されるべきである
Client State Global State Server State Reactの状態には3種類ある UIの状態 トースト表示 APIレスポンス
クライアントの状態 サーバーの状態
Client State Global State Server Stateが存在しない UIの状態 トースト表示 APIレスポンス
Redux
Client State Global State Server Stateが存在しない UIの状態 トースト表示 APIレスポンス Reduxでは、
Server Stateを Global State として管理している
03. Client State vs Server State
Client StateとServer State の違いは? 以後、Client State = Client State +
Global State
Client State vs Server State Client State Server State 所有者
クライアントが完全に所有している リモートに操作されうる 同期性 同期的に使用することができる 非同期的に使用する必要がある 最新性 常に最新の状態である 状態が古くなる可能性がある
Client State vs Server State Client State Server State 所有者
クライアントが完全に所有している リモートに操作されうる 同期性 同期的に使用することができる 非同期的に使用する必要がある 最新性 常に最新の状態である 状態が古くなる可能性がある
04. 非同期の状態を管 理する
ReduxとReact Queryでの 非同期な状態の実装を比較 loadingで検証
Reduxの場合
React Queryの場合
React Queryの場合
React Queryは非同期の 状態管理ライブラリだ
05. キャッシュを 管理する
Client State vs Server State Client State Server State 所有者
クライアントが完全に所有している リモートに操作されうる 同期性 同期的に使用することができる 非同期的に使用する必要がある 最新性 常に最新の状態である 状態が古くなる可能性がある
状態をなるべく 最新に保ちたい
useQueryを使用した データフェッチの流れ 1. useQueryがコンポーネントで呼ばれ、データフェッチを開始 2. queryKeyを参考にキャッシュを確認する - キャッシュヒットした場合、キャッシュされたデータをコンポーネントに返却 - キャッシュヒットしなかった場合、または、キャッシュヒットしたがキャッシュが
stale状態の場 合は3に進む 3. バックグラウンドで新しいデータを fetchしてアップデートする 4. 新しいデータをキャッシュに保存して再レンダリングする
なるべくキャッシュを 返してfetchを減らしたい
StaleTimeとcacheTime • staleTime ◦ キャッシュをstale(古くなったとみなす) 状態にするまでの期間 ◦ デフォルト:0 • cacheTime
◦ キャッシュをガベージコレクション(メモリ領域の開放)するまでの 時間 ◦ デフォルト:5分
StaleTimeを使用する • staleTime:0 ◦ 常に最新のデータを取得する • staleTime:Infinity ◦ キャッシュが常にfreshなのでネットワークのリクエストが走らず、 キャッシュからデータを取得する
◦ 自分しか変更できないデータに有効
StaleTimeを使用する • staleTime:0 ◦ 基本はこの設定で良い • staleTime:Infinity ◦ データが更新されるタイミングがわかっていれば Infinityにして、更新時に明示的にinvalidateする
最新性を優先する
Client State vs Server State Client State Server State 所有者
クライアントが完全に所有している リモートに操作されうる 同期性 同期的に使用することができる 非同期的に使用する必要がある 最新性 常に最新の状態である 状態が古くなる可能性がある
Thanks!!!
Thanks!!! • Twitter ◦ https://twitter.com/ytaisei_ • Qiita ◦ https://qiita.com/taisei-13046 •
Zenn ◦ https://zenn.dev/taisei_13046