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
今更Riverpod2.0について調べて発表する
Search
Kuroneko-mayuge
September 23, 2023
Business
310
0
Share
Embed
Copy iframe code
Copy JS code
Copy link
Start on current slide
今更Riverpod2.0について調べて発表する
今更Riverpod2.0について調べて発表する
Kuroneko-mayuge
September 23, 2023
More Decks by Kuroneko-mayuge
See All by Kuroneko-mayuge
Try Riverpod2.0
ryo2929
1
130
Other Decks in Business
See All in Business
楽しかった仕事の理由を深掘りしてみた
suzakiyoshito
0
150
サムコ株式会社 第47期第3四半期決算概要
tsuchihashi
0
350
ログラス会社紹介資料 / Loglass Company Deck
loglass2019
17
550k
データ品質とメタデータ管理で実現する構造化・非構造化データ活用のユースケース紹介
kawanago
0
200
会社紹介資料
nipap
0
180
Eight Career Recruiting Pitch_2605
sredoa
0
1.1k
開発時間2時間!gemma 4で動くローカルAIマルチエージェント構築(Python標準ライブラリ縛り)
hideyuki_ogawa
0
270
2026.6_中途採用資料.pdf
superstudio
PRO
5
110k
株式会社SHO-CASE_会社案内20260525
20201001
0
210
会社説明資料
kurashima
0
820
jpax-introduction
jpax
0
1.2k
採用ピッチ資料_耳川広域森林組合
mimirin
0
350
Featured
See All Featured
Exploring the relationship between traditional SERPs and Gen AI search
raygrieselhuber
PRO
2
4k
AI in Enterprises - Java and Open Source to the Rescue
ivargrimstad
0
1.3k
Understanding Cognitive Biases in Performance Measurement
bluesmoon
32
2.9k
Accessibility Awareness
sabderemane
1
140
Learning to Love Humans: Emotional Interface Design
aarron
275
41k
The Web Performance Landscape in 2024 [PerfNow 2024]
tammyeverts
12
1.2k
Paper Plane
katiecoart
PRO
1
51k
Test your architecture with Archunit
thirion
1
2.3k
Taking LLMs out of the black box: A practical guide to human-in-the-loop distillation
inesmontani
PRO
3
2.3k
Building a Scalable Design System with Sketch
lauravandoore
463
34k
Amusing Abliteration
ianozsvald
1
200
A designer walks into a library…
pauljervisheath
211
24k
Transcript
Riverpod2 系について調べたことを話 す 株式会社Relic Ryo Kuroki
About Me Ryo Kuroki 株式会社Relic Flutter 歴 業務では約3 ヶ月 個人開発で約1
年 EXPERIENCE
発表の対象者と目的 目的 Riverpod ver2.x についてこんな感じなんだ〜と知ってもらう 対象者 🙆 Riverpod は聞いたことあるが、まだ使ったことがない方(特にver2.x )
🙅♀️ Riverpod を熟知されている方、ver2.x もすぐに順応できる方
なぜプロバイダが必要なのか アプリの様々な場所からステートにアクセス できるようになる シングルトンや依存性注入、 などを分かりやすく代替することができる ステートを別のプロバイダのステートと簡単 に組み合わせる事が可能 複数のオブジェクトを組み合わせて 1 つのステートにまとめなくていい
テスト容易性を高める パフォーマンス最適化 同じ型のオブジェクトを公開するプロバイダ を 複数宣言できる final cityProvider = Provider((ref) => 'London'); final countryProvider = Provider((ref) => 'England');
v2.0 以降のProvider の種類 Provider 概要 NotifierProvider v2.0から登場。メインの機能 AsyncNotifierProvider v2.0から登場。FutureProviderではできない状態の変更が可能 Provider
これまで通り。Repositoryなどの状態を持たないケースで利用 StateProvider NotifierProviderより非常に単純な場合。レガシー? StateNotifierProvider NotifierProviderを推奨と明記されている FutureProvider AsyncNotifierProviderを使うほどでもない、状態の変更を伴わない単純なユースケース StreamProvider FutureProviderのStream版 ChangeNotifier 元々非推奨。ChangeNotifierProviderからの置き換えの手始めに最も簡単。
code generation によってProvider の種類を意識せず最適なものを実装しやすい
初期値の設定を わかりやすく実装しやすい ここで、 ref.watch(otherProvider) などと、 他のprovider を参照できる 状態を変更するメソッドを UI に公開する
code generation によって NotifierProvider が生成される watch で監視しておくと便利 part 'main.g.dart'; @riverpod class Todos extends _$Todos { @override List<Todo> build() { return [ Todo(description: 'Learn Flutter', completed: true), Todo(description: 'Learn Riverpod'), ]; } void addTodo(Todo todo) { state = [...state, todo]; } } flutter pub run build_runner watch コード自動生成のための ファイル名とアノテーション
class TodoListView extends ConsumerWidget { const TodoListView({super.key}); @override Widget build(BuildContext
context, WidgetRef ref) { List<Todo> todos = ref.watch(todosProvider); return ListView( children: [ for (final todo in todos) CheckboxListTile( value: todo.completed, onChanged: (value) => ref.read(todosProvider.notifier).toggle(todo.id), title: Text(todo.description), ), ], ); } } UI 側の利用は特に変更なし UI 側でstate の値をwatch UI 側からstate を変更する
// 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 個しか設定できなかったのが、任意で追加できるようになった