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
チームで採用しているriverpodを使ったFlutterのアーキテクチャとriverpod ...
Search
Kakeru Nakabachi
August 06, 2021
Programming
6
4.9k
チームで採用しているriverpodを使ったFlutterのアーキテクチャとriverpod v1.0.0
Kakeru Nakabachi
August 06, 2021
Tweet
Share
More Decks by Kakeru Nakabachi
See All by Kakeru Nakabachi
Flutterアプリで可用性を向上させたFeatureFlagの運用戦略とその方法
b4tchkn
0
1.6k
Inside Flutter Text
b4tchkn
1
270
Flutterアプリのセキュリティ対策を考えてみる
b4tchkn
6
7.6k
Textの構造を理解する/Understanding the Structure of Text
b4tchkn
3
2.5k
Other Decks in Programming
See All in Programming
Nostalgia Meets Technology: Super Mario with TypeScript
manfredsteyer
PRO
0
110
テレメトリーシグナルが導くパフォーマンス最適化 / Performance Optimization Driven by Telemetry Signals
seike460
PRO
2
150
モックわからないマン卒業記 ~振る舞いを起点に見直した、フロントエンドテストにおけるモックの使いどころ~
tasukuwatanabe
3
420
生成 AI 時代のスナップショットテストってやつを見せてあげますよ(α版)
ojun9
0
300
AIコードレビューの導入・運用と AI駆動開発における「AI4QA」の取り組みについて
hagevvashi
0
550
SourceGeneratorのマーカー属性問題について
htkym
0
210
Claude Codeログ基盤の構築
giginet
PRO
7
3.6k
Reactive ❤️ Loom: A Forbidden Love Story
franz1981
2
150
Angular-Apps smarter machen mit Gen AI: Lokal und offlinefähig - Hands-on Workshop!
christianliebel
PRO
0
130
どんと来い、データベース信頼性エンジニアリング / Introduction to DBRE
nnaka2992
1
330
Understanding Apache Lucene - More than just full-text search
spinscale
0
140
Fundamentals of Software Engineering In the Age of AI
therealdanvega
2
290
Featured
See All Featured
ピンチをチャンスに:未来をつくるプロダクトロードマップ #pmconf2020
aki_iinuma
128
55k
<Decoding/> the Language of Devs - We Love SEO 2024
nikkihalliwell
1
160
Designing Powerful Visuals for Engaging Learning
tmiket
0
290
Claude Code のすすめ
schroneko
67
220k
Improving Core Web Vitals using Speculation Rules API
sergeychernyshev
21
1.4k
Have SEOs Ruined the Internet? - User Awareness of SEO in 2025
akashhashmi
0
300
How To Stay Up To Date on Web Technology
chriscoyier
790
250k
What does AI have to do with Human Rights?
axbom
PRO
1
2.1k
Building Applications with DynamoDB
mza
96
7k
From Legacy to Launchpad: Building Startup-Ready Communities
dugsong
0
180
Building AI with AI
inesmontani
PRO
1
820
The AI Revolution Will Not Be Monopolized: How open-source beats economies of scale, even for LLMs
inesmontani
PRO
3
3.2k
Transcript
チームで採用しているriverpodを使った Flutterのアーキテクチャとriverpod v1.0.0 b4tchkn Flutter x Kotlin Multiplatform by CyberAgent
#4 2021/08/06 #ca_flutter_kmm
About me Kakeru Nakabachi batch(@b4tchkn) 2
今日のゴール • ちょっとこの部分参考にできるかも • riverpodで状態管理いいかも • CAもFlutterで色々やってるんだな👀 3
アジェンダ • riverpodの簡単な紹介 • チームのFlutterプロジェクトアーキテクチャ • riverpod使用ルールについて 4
riverpod 5
• もともとあった、Providerという状態管理ライブラリの問題点を解消したやつ • DIもこれで実現できる • テスタブルなコードを保証してくれる • 最近 v1.0.0に乗り換え •
hooks_riverpod • flutter_riverpod • riverpod https://riverpod.dev/docs/getting_started/ riverpod 6
• もともとあった、Providerという状態管理ライブラリの問題点を解消したやつ • DIもこれで実現できる • テスタブルなコードを保証してくれる • 最近 v1.0.0に乗り換え •
hooks_riverpod • flutter_riverpod • riverpod https://riverpod.dev/docs/getting_started/ riverpod 7
hooks_riverpod flutter_hooksと併用する使い方 HookConsumerWidgetを使って中でref.watchなど便利メソッドが呼べる 8
hooks_riverpod 公式にも載ってる簡単なサンプル 9
hooks_riverpod riverpodを使うプロジェクトではAppを ProviderScopeでラップする 10
hooks_riverpod Stringを配るProvider 11
hooks_riverpod ProviderをWidget内で監視 12
hooks_riverpod riverpod v1.0.0での割と大きな変更点 13
チームのFlutterアーキテクチャ 14
全体像 15 UI State Domain Data
全体像 16 UI State Domain Data
• Service ◦ DioとRetrofitを使った RemoteDataSource ◦ 定義したabstract class(interface)から実 際にリクエストするコードを生成 •
Database ◦ SharedPreferencesを使った LocalDataSource ◦ Key - Valueでデータを永続化 同ドメインに関わる複数のメソッドを定義できる getArticle(String id)とか Data 17
Data • 実際にリクエストするメソッド 18
Data • Dioの依存をriverpodのProviderを使ってDI • Dioに依存したdatasourceのインスタンスをProviderで配布 19
全体像 20 UI State Domain Data
Domain ビジネスオブジェクトを含む、アプリケーションの中核となるレイヤー メソッドは1つしか実装できない UseCaseは他のUseCaseへの参照はできない Stateが複数UseCaseを持つのはOK 21
Domain UseCaseはDataSourceに依存 22
Domain UseCaseはDataSourceに依存 DataSourceで定義したProviderを 使ってUseCaseのインスタンスを配 布する際にDIして提供する 23
Domain DataSourceのコールにパラメータが必要 な場合 24
Domain DataSourceのコールにパラメータが必要 な場合 パラメータが1つでもUseCaseParamのオ ブジェクトを作ってUseCaseに渡す 25
全体像 26 UI State Domain Data
State 1つの状態だけを持つViewModel的な存在 Recoilの思想を取り入れて、1つのStateの粒度を可能な限り小さくする 27 https://recoiljs.org/
State StateのProviderを作る時はStateNotifierProviderを使う 28
State 29 トップ画面 記事一覧画面
State UseCaseの依存解決にParamが必要な場合 familyを使ってProviderを作るパラメータを増やす このときParamが変更されると古いParamを持ったProviderは再利用されず溜まってい き、メモリリークの原因となるためautoDisposeもセットで使う 30
Selector Stateをなにかしら計算してUIに渡したいときに定義 複数のStateを参照して計算した値をSelectorで定義してUIに配布もできる 31
State よくあるStateの動き 32
State よくあるStateの動き 33 loading Request Request
よくあるStateの動き State 34 loading Data Data
State よくあるStateの動き 35 idle(loaded) Data Data Data
State よくあるStateの動き(異常系) 36 idle(loaded) Error Data Data
State これらの状態をAsycEntity、 AsyncStateNotifierで表現 37
全体像 38 UI State Domain Data
UI - Connected Screen StatefulなPage StateとStatelessなHogePageを繋ぎこむ役目 StateProviderの保持と、loadingなどの状態に よってWidgetを出し分けるため DefaultContainerでAsyncEntityの値を処理す る
39
UI - Connected Screen DefaultContainer Stateから渡ってきた複数のAsyncEntityの値を処理してWidgetの出し分けを担う 40 ロード中 ロード終了 エラー発生
UI - Stateless Screen StateをもたないWidget群 • ListView • TextView •
Container • Column • … 41
riverpod使用ルール 42
riverpod使用ルール Providerの作り方はたくさんある • Provider • StreamProvider • StateProvider • StateNotifierProvider
• FutureProvider https://riverpod.dev/docs/concepts/providers 43
Providerのreadの仕方もいっぱいある https://riverpod.dev/docs/concepts/reading riverpod使用ルール 44
riverpod使用ルール ルール①:FutureProvider / StreamProviderの代わりに StateNotifierProvider+AsyncStateNotifier 45 NG OK
riverpod使用ルール ルール②:StateProviderの代わりにStateNotifierProvider+StateController 46 NG OK
riverpod使用ルール ルール③:Provider作成時はref.readは使わないでref.watchのみで統一 47 NG OK
riverpod使用ルール ▪ まとめ 1. FutureProvider / StreamProviderの代わりに StateNotifierProvider+AsyncStateNotifier 2. StateProviderの代わりにStateNotifierProvider+StateController
➢ プロジェクトで使うProviderをProviderとStateNotifierProviderに制限 3. Provider作成時はref.readは使わないでref.watchのみで統一 ➢ 依存しているProviderが再生成されたときに、変化した値を購読できるよ うにするため ➢ 設計の統一性、Providerの依存を見やすくする 48
参考リンク 49 • https://riverpod.dev/docs/getting_started • https://recoiljs.org/ • https://zenn.dev/riscait/books/flutter-riverpod-practical-introduction/viewer/mig rate-to-v1
Thank you 50