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
雰囲気でやってる人向けの Redux 再入門
Search
Sponsored
·
Your Podcast. Everywhere. Effortlessly.
Share. Educate. Inspire. Entertain. You do you. We'll handle the rest.
→
Yoshihide Jimbo
January 18, 2019
Technology
21
6.6k
雰囲気でやってる人向けの Redux 再入門
ng-kyoto Angular Meetup #9 での発表資料です。
https://ng-kyoto.connpass.com/event/113358/
Yoshihide Jimbo
January 18, 2019
Tweet
Share
More Decks by Yoshihide Jimbo
See All by Yoshihide Jimbo
高齢者でも使えるプロダクトUIの挑戦 / Designing User Interfaces for the Elderly
jmblog
32
28k
unstated-next による Redux に頼らない状態管理の考察
jmblog
9
5.3k
わかりやすいグラフを作ろう
jmblog
3
1.4k
Web Components で 社内 UI ライブラリを作っている話
jmblog
11
4.4k
gulp: The Good Parts
jmblog
29
6k
CSS in JS と CSS Modules
jmblog
25
4.7k
PostCSS とは何か
jmblog
38
10k
Kaizen Platform における UI ライブラリのワークフロー
jmblog
30
6.2k
フロントエンドエンジニアのための Dotfiles
jmblog
53
8.6k
Other Decks in Technology
See All in Technology
~Everything as Codeを諦めない~ 後からCDK
mu7889yoon
3
520
旅先で iPad + Neovim で iOS 開発・執筆した話
zozotech
PRO
0
100
(技術的には)社内システムもOKなブラウザエージェントを作ってみた!
har1101
0
330
Bedrock PolicyでAmazon Bedrock Guardrails利用を強制してみた
yuu551
0
260
Amazon Bedrock Knowledge Basesチャンキング解説!
aoinoguchi
0
170
モダンUIでフルサーバーレスなAIエージェントをAmplifyとCDKでサクッとデプロイしよう
minorun365
4
230
生成AIを活用した音声文字起こしシステムの2つの構築パターンについて
miu_crescent
PRO
3
230
Oracle Cloud Observability and Management Platform - OCI 運用監視サービス概要 -
oracle4engineer
PRO
2
14k
20260208_第66回 コンピュータビジョン勉強会
keiichiito1978
0
200
プロダクト成長を支える開発基盤とスケールに伴う課題
yuu26
4
1.4k
AIエージェントに必要なのはデータではなく文脈だった/ai-agent-context-graph-mybest
jonnojun
1
250
Kiro IDEのドキュメントを全部読んだので地味だけどちょっと嬉しい機能を紹介する
khmoryz
0
210
Featured
See All Featured
Distributed Sagas: A Protocol for Coordinating Microservices
caitiem20
333
22k
Efficient Content Optimization with Google Search Console & Apps Script
katarinadahlin
PRO
1
330
StorybookのUI Testing Handbookを読んだ
zakiyama
31
6.6k
Data-driven link building: lessons from a $708K investment (BrightonSEO talk)
szymonslowik
1
920
Put a Button on it: Removing Barriers to Going Fast.
kastner
60
4.2k
Highjacked: Video Game Concept Design
rkendrick25
PRO
1
290
How to Build an AI Search Optimization Roadmap - Criteria and Steps to Take #SEOIRL
aleyda
1
1.9k
Noah Learner - AI + Me: how we built a GSC Bulk Export data pipeline
techseoconnect
PRO
0
110
Fight the Zombie Pattern Library - RWD Summit 2016
marcelosomers
234
17k
The World Runs on Bad Software
bkeepers
PRO
72
12k
Statistics for Hackers
jakevdp
799
230k
I Don’t Have Time: Getting Over the Fear to Launch Your Podcast
jcasabona
34
2.6k
Transcript
雰囲気でやってる⼈向けの Redux 再⼊⾨ ng-kyoto Angular Meetup #9 | Jan 18,
2019
神保 嘉秀 @jmblog じんぼ よしひで
Redux(あるいは ngrx)使ってる⼈
store とか action とか reducer とか dispatch とか middleware とか
実はちゃんと把握してなくて、 雰囲気でコード書いてる⼈
それな
確かに Redux は覚えることが多い (ように⾒える)
ほんとうはすごくシンプルなライブラリ
Redux の概念が理解できていれば ngrx だって vuex だってすぐ理解できる。
Store 登場⼈物その1
そもそも、なぜ Redux を使うのか? アプリケーション全体の state 管理に秩序をもたらすため TUBUF
TUBUF 例えば、グローバル変数で state を管理することもできる
TUBUF ただし、アプリの複雑さが増すと、 state が「いつ」「なぜ」「どのように」 変わったのか把握できなくなり、 制御不能となる。
TUBUF 4UPSF そんな破綻を防ぐために、Store という「管理会社」を⽤意して、 そのなかで state を厳重に管理しましょうというのが Redux
Store の役割 • state を内部に保持する • state へアクセスするための⼿段を提供する • state
の更新を通知する⼿段を提供する • state を更新するための⼿段を提供する
Store の役割 • state を内部に保持する • state へアクセスするための⼿段を提供する • state
の更新を通知する⼿段を提供する • state を更新するための⼿段を提供する
store.getState() で最新の state を取得する
Store の役割 • state を内部に保持する • state へアクセスするための⼿段を提供する • state
の更新を通知する⼿段を提供する • state を更新するための⼿段を提供する
store.subscribe() で state 変更時に実⾏したい関数を登録する
Store の役割 • state を内部に保持する • state へアクセスするための⼿段を提供する • state
の更新を通知する⼿段を提供する • state を更新するための⼿段を提供する
この⼿続きがちょっと⾯倒くさい
Action 登場⼈物その2
TUBUF 4UPSF "DUJPO state を更新したいときの⼿続きとして、 Action という「依頼状」をStore に送らなければならない。
TUBUF 4UPSF "DUJPO Action は Store が⽤意した⼿段 = store.dispatch(action) を
使って送る。("dispatch" は「送る」という意味) TUPSFEJTQBUDI
"DUJPO Action の実態は、JavaScript の Plain Object。 type というプロパティを必ず持たせることが唯⼀の規約。
"DUJPO この type プロパティは Action Type と呼ばれる。 どういう state 更新をしてもらいたいかを
Store 側に伝えるための 「合⾔葉」みたいなもの。
"DUJPO また、Action を⽣成する関数は Action Creator と呼ばれる。
Action Type も Action Creator も Action に付随するサブキャラ。
では、依頼状(Action)を受け取った Store はどうするか?
Reducer 登場⼈物その3
TUBUF 4UPSF 3FEVDFS "DUJPO Store に届いた Action(依頼状)は、Store 内部にいる Reducer の元に届けられる。
TUBUF 4UPSF 3FEVDFS "DUJPO Reducer は受け取った依頼(Action)の中⾝を⾒て、 state を更新する。
4UPSF 3FEVDFS Reducer は Store の中で働くので、Store を作成する際に 引数で渡して、あらかじめ待機しておいてもらう。
4UPSF 3FEVDFS ⼀⼈の Reducer がすべての依頼をさばくこともできるが、 複数の Reducer に分担させることもできる。 その場合は combineReducers()
を使う。
Reducer の実態は、ただの関数。 「今の state」と「Action」を受け取り、「新しい state」を返す。 3FEVDFS
3FEVDFS 具体的には、Action の type プロパティ(Action Type)をみて、 それに応じた state の更新処理を immutable
に⾏う。 知らない type だったら今の state をそのまま返す。
ここまでのまとめ
TUBUF 4UPSF 3FEVDFS "DUJPO
Middleware 登場⼈物その4
TUBUF 4UPSF 3FEVDFS "DUJPO .JEEMFXBSF Middleware は、送られてきた Action を Reducer
の⼿前で捕まえて、 ゴニョゴニョすることができる。
例えば…
送られてきた Action の中⾝をログに出⼒したり、
特定の条件に該当する Action をもみ消したり、
Action に⾃前のプロパティルールを追加したり、
Action として、Plain Object だけではなく、 関数も送ることができるようにしたり(redux-thunk)、 (こういった、あとで実⾏してもらうために預ける関数のことを thunk といいます)
Action として、Plain Object だけではなく、 Promise も送ることができるようにしたり(redux-promise)、
特定の Action Type が来たら、スレッドのようなものを起動して、 そこで副作⽤のある処理を実⾏したり(redux-saga)、
という感じで、何でもできる
state を更新する流れのまとめ
TUBUF 4UPSF 3FEVDFS "DUJPO .JEEMFXBSF
シンプルでしょ?
おまけ
Repatch
TUBUF 4UPSF 3FEVDFS "DUJPO Redux(おさらい)
Redux がわずらわしい点 Action が存在するせいで、コードが冗⻑になる。 state の更新処理を1つ追加するだけで、 Reducer だけではなく、Action Type
も Action Creator も 増やさなければならない。 ⼀つ⼀つは単純なコードだが、だからこそ⾯倒くさい。
だったら、Action を捨てて、 Reducer を直接 dispatch しちゃばいいじゃない Repatch
TUBUF 4UPSF 3FEVDFS Repatch
Repatch
でも使っています
Angular だったらこういうのもあるらしい
MobX
state ⾃体が超賢いよ! TUBUF MobX
MobX の特徴 • state を observable にする • observer を⽤意すれば、state
の変更が⾃動的に伝わる • state は直接変更を加えてOK(immutable にしなくてよい)
MobX
state の更新は Redux より簡単にできるが、 その分、雑に使うこともできるので、 雰囲気で使うと怪我をしそう。 MobX
おわり "MMJDPOTBSFEFTJHOFECZ'SFFQJDGSPN'MBUJDPO