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
Try Riverpod2.0
Search
Kuroneko-mayuge
September 12, 2023
Business
130
1
Share
Embed
Copy iframe code
Copy JS code
Copy link
Start on current slide
Try Riverpod2.0
Try Riverpod2.0
Kuroneko-mayuge
September 12, 2023
More Decks by Kuroneko-mayuge
See All by Kuroneko-mayuge
今更Riverpod2.0について調べて発表する
ryo2929
0
310
Other Decks in Business
See All in Business
"分からないまま走る"をやめたら不確実性に向き合えるチームになっていった話 ~開発指標で語るプロセス改善~
bicstone
1
220
営業、広報、開発。 多面的なAIネイティブ化のための 基盤について
timakin
0
210
How SureSmile Clear Aligners Work Step-by-Step Guide for Beginners
burtonadvancedentalmi
0
150
楽しかった仕事の理由を深掘りしてみた
suzakiyoshito
0
150
自分のハンドルを握る〜AI時代だからこそ求められるセルフマネジメントの技術/Self-Management Skills Needed More Than Ever in the AI Era
ikuodanaka
1
420
CompanyDeck_v6.5.pdf
xid
3
27k
Sotas Company Deck / 会社紹介資料
sotas
0
680
株式会社Domuz会社紹介資料(採用)
kimpachi_d
0
58k
元ウェブエンジニアが軸を持って人事に転職したら大きくステップアップした話 / Web Dev to HR with a Purpose Driven Career Leap
tbpgr
2
2.5k
エイターリンク株式会社 会社紹介資料
aeterelink
0
43k
CEOの価値観を言語化することでメンバーの心を動かすマネジメントを体得するワークショップ
nagam3618
1
280
DMM.com コーポレートブック
dmm
2
490k
Featured
See All Featured
30 Presentation Tips
portentint
PRO
1
320
Digital Projects Gone Horribly Wrong (And the UX Pros Who Still Save the Day) - Dean Schuster
uxyall
1
1.7k
More Than Pixels: Becoming A User Experience Designer
marktimemedia
3
440
Why Our Code Smells
bkeepers
PRO
340
58k
Optimizing for Happiness
mojombo
378
71k
The Myth of the Modular Monolith - Day 2 Keynote - Rails World 2024
eileencodes
28
3.5k
Designing Experiences People Love
moore
143
24k
Agile Actions for Facilitating Distributed Teams - ADO2019
mkilby
0
210
Visualization
eitanlees
152
17k
Efficient Content Optimization with Google Search Console & Apps Script
katarinadahlin
PRO
1
620
How to train your dragon (web standard)
notwaldorf
97
6.7k
The Art of Programming - Codeland 2020
erikaheidi
57
14k
Transcript
Riverpod2 系への挑戦 株式会社Relic Ryo Kuroki
About Me Ryo Kuroki 株式会社Relic, 2023 6 月中途入社 Flutter 歴
業務では約3 ヶ月 個人開発で約1 年 IT エンジニア歴 約3 年 主にFE Relic では「coordimate 」というモバイルアプリサービスの FE 開発とPDM っぽいことをしています EXPERIENCE
発表の対象者と目的 目的 Riverpod ver2.x についてこんな感じなんだ〜始められそう〜と知ってもらう 対象者 🙆 Riverpod は聞いたことあるが、まだ使ったことがない方(特にver2.x )
🙅♀️ Riverpod を熟知されている方、ver2.x もすぐに順応できる方
agenda なぜプロバイダが必要なのか Riverpod v2.0 以降のProvider の種類 Riverpod v2 の大きな特徴 実際の導入
終わりに 1 2 3 4 5
agenda なぜプロバイダが必要なのか Riverpod v2.0 以降のProvider の種類 Riverpod v2 の大きな特徴 実際の導入
終わりに 1 2 3 4 5
なぜプロバイダが必要なのか アプリの様々な場所からステートにアクセス できるようになる シングルトンや依存性注入、InheritedWidget などを分かりやすく代替することができる ステートを別のプロバイダのステートと簡単 に組み合わせる事が可能 複数のオブジェクトを組み合わせて 1 つのステートにまとめなくていい
テスト容易性を高める パフォーマンス最適化 同じ型のオブジェクトを公開するプロバイダ を 複数宣言できる final cityProvider = Provider((ref) => 'London'); final countryProvider = Provider((ref) => 'England');
agenda なぜプロバイダが必要なのか Riverpod v2.0 以降のProvider の種類 Riverpod v2 の大きな特徴 実際の導入
終わりに 1 2 3 4 5
v2.0 以降のProvider の種類 Provider 概要 NotifierProvider v2.0から登場。メインの機能 AsyncNotifierProvider v2.0から登場。FutureProviderではできない状態の変更が可能 Provider
これまで通り。Repositoryなどの状態を持たないケースで利用 StateProvider NotifierProviderより非常に単純な場合。レガシー? StateNotifierProvider NotifierProviderを推奨と明記されている FutureProvider AsyncNotifierProviderを使うほどでもない、状態の変更を伴わない単純なユースケース StreamProvider FutureProviderのStream版 ChangeNotifier 元々非推奨。ChangeNotifierProviderからの置き換えの手始めに最も簡単。
agenda なぜプロバイダが必要なのか Riverpod v2.0 以降のProvider の種類 Riverpod v2 の大きな特徴 実際の導入
終わりに 1 2 3 4 5
code generation によってProvider の種類を意識せず最適なものを実装しやすい
(Async) NotifierProvider カスタム・イベントに反応した後、 時間の経過とともに変化する状態を公開する ある状態を変更するためのロジック (別名「ビジネスロジック」)を一箇所に集中させることで、 長期にわたる保守性を向上させる Notifier( 時間とともに変化する状態を公開するクラス) をリッスンし、公開するために使用されるプロバイダ
初期値の設定を わかりやすく実装しやすい ここで、 ref.watch(otherProvider) などと、 他のprovider を参照できる 状態を変更するメソッドを UI に公開する
code generation によって Notifier とNotifierProvider が生成され る @riverpod class Todos extends _$Todos { @override List<Todo> build() { return []; } void addTodo(Todo todo) { state = [...state, todo]; } } final todosProvider = NotifierProvider<TodosNotifier, List<Todo>>(() { return TodosNotifier(); });
// Riverpod 1系 final fetchUserProvider = FutureProvider.autoDispose.family<User, int>((ref, userId) async
{ final json = await http.get('api/user/$userId'); return User.fromJson(json); }); // Riverpod 2系 @riverpod Future<User> fetchUser(FetchUserRef ref, {required int userId, required int page}) async { final json = await http.get('api/user/$userId/$page'); return User.fromJson(json); } autoDispose がデフォルトでON になった ( 破棄せず保持したい時はkeepAlive:true と明示する) 引数を1 個しか設定できなかったのが、任意で追加できるようになった
agenda なぜプロバイダが必要なのか Riverpod v2.0 以降のProvider の種類 Riverpod v2 の大きな特徴 実際の導入
終わりに 1 2 3 4 5
// Riverpod導入前はMultiProviderを利用していたので、削除 MultiProvider( providers: [ ChangeNotifierProvider(create: (_) => AppUser()), ChangeNotifierProvider(create:
(_) => EtcProvider()) MultiProvider の部分を削除 自分の場合は、runApp の配下をProviderScope で囲んだ runApp( child: const ProviderScope( child: MyApp(), )) 導入前 導入後
// providerパッケージのChangeNotifierProviderを利用していた class AppUser extends ChangeNotifier { /// ユーザーIDの設定や、ユーザー名の変更メソッドなど }
とりあえずRiverpod のChangeNotifierProvider を利用して、コード変更量の少なさを重視 ※ChangeNotifierProvider が公式に非推奨であることと、その理由は理解する import 'package:flutter_riverpod/flutter_riverpod.dart'; // AppUserクラスは変更なし final appUserNotifierProvider = ChangeNotifierProvider<AppUserNotifier>((ref) { return AppUserNotifier(); }) 導入前 導入後
// class UserProfilePage extends StatefulWidget { class UserProfilePage extends ConsumerStatefulWidget
{ とりあえずStatefulWidget→ConsumerStatefulWidget に変更 ※Consumer,ConsumerWidget よりも再ビルドのコストが大きくなりそうなことを理解する // String userId = Provider.of<AppUser>(context).userId; String userId = ref.watch(appUserNotifierProvider).userId; // Provider.of<AppUser>(context, listen: false).setAppUser(id); ref.read(appUserNotifierProvider.notifier).setAppUser(id); ステートの値をUI 側で監視、変更する方法はあまり変わらない Riverpod1.0 を使っていた場合は特に変更なし
import 'package:riverpod_annotation/riverpod_annotation.dart'; part 'note_list_provider.g.dart'; @riverpod class NoteList extends _$NoteList {
@override // buildの引数に指定すると、generatorの方で認識される FutureOr<List<Note?>> build(String userId) async { return Future.value(_fetchNotes(userId)); } Future<List<Note?>> _fetchNotes(String userId) async { list = []; // Firestoreからの取得などの非同期処理でlistを更新 // AsyncValue.data()で非同期処理が成功した時のデータが取得できるので、状態を更新 state = AsyncValue.data(list); return list; } Future<List<ExchangeNote?>> reloadNotes(String userId) async { // AsyncLoading()を挟めば、Consumer側でLoading画面を表示できる state = const AsyncLoading(); await Future.delayed(const Duration(seconds: 1)); return _fetchNotes(userId); } }
flutter pub run build_runner build ターミナルでコマンド実行すると、自動で認識してAsyncNotifier とそのProvider が生成される final myNotes
= ref.watch(noteListProvider(userId)) myNotes.when( loading: () => WidgetUtils().createProgressIndicator(), error: (error, stack) => Center( child: Text('エラーが発生しました\n$error'), ), data: (myNotes) { // List表示とか } UI 側での使い方はRiverpod1 系と変わらない FutureValue を監視して、Loading 、エラー時、成功時の値を直感的に実装できる
agenda なぜプロバイダが必要なのか Riverpod v2.0 以降のProvider の種類 Riverpod v2 の大きな特徴 実際の導入
終わりに 1 2 3 4 5
信頼性の高い、最新の情報を キャッチアップし続ける 公式で基礎を理解する。 なぜそれを導入しなければいけないのか、 プロダクトの課題とそれに対する解決策が あっているのかを理解する。 「よく使われているもの」に惑わされない。 スピードと品質のバランスをとる 新規事業は常にシビアな時間との勝負。 だからこそ変更容易性を将来も担保できるよう
に、技術的負債を如何に蓄積させないか、新しい 便利な技術に、既存システムをどう順応させてい くかも考えなくてはならない。
参考にしたdoc https://docs-v2.riverpod.dev/docs/why_riverpod https://qiita.com/chooyan_eng/items/1c0c33175dddb837a6f5