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
株式会社Domuz会社紹介資料(採用)
kimpachi_d
0
58k
“使われているハーネス/使われていないハーネス”を可視化するところから始めた話
sugamoto
0
220
CompanyDeck_v6.5.pdf
xid
3
27k
データ品質とメタデータ管理で実現する構造化・非構造化データ活用のユースケース紹介
kawanago
0
190
malna-recruiting-pitch
malna
0
22k
採用ピッチ資料_キヨモトテックイチ
satoshi01
0
200
会社説明資料
kurashima
0
820
ITが何の略なのかも知らないままエンジニアになっちゃったのでインターネットに生き恥を晒してみた話
m_k__77
1
280
VISASQ: ABOUT DEV TEAM
eikohashiba
6
44k
FIGEO採用ピッチ資料
figeohr
0
350
BacklogとAIで変わった、 ウェブディレクターの仕事のリアル
wattlaa
0
270
ログラス会社紹介資料 / Loglass Company Deck
loglass2019
17
550k
Featured
See All Featured
Tips & Tricks on How to Get Your First Job In Tech
honzajavorek
1
540
A Guide to Academic Writing Using Generative AI - A Workshop
ks91
PRO
1
330
Distributed Sagas: A Protocol for Coordinating Microservices
caitiem20
333
22k
SEOcharity - Dark patterns in SEO and UX: How to avoid them and build a more ethical web
sarafernandez
0
200
JAMstack: Web Apps at Ludicrous Speed - All Things Open 2022
reverentgeek
1
470
Groundhog Day: Seeking Process in Gaming for Health
codingconduct
0
210
JavaScript: Past, Present, and Future - NDC Porto 2020
reverentgeek
52
6k
Tell your own story through comics
letsgokoyo
1
950
Ten Tips & Tricks for a 🌱 transition
stuffmc
0
130
Unlocking the hidden potential of vector embeddings in international SEO
frankvandijk
0
840
4 Signs Your Business is Dying
shpigford
187
22k
[RailsConf 2023] Rails as a piece of cake
palkan
59
6.7k
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 個しか設定できなかったのが、任意で追加できるようになった