Introduzione
Prova Riverpod online
Per farti un'idea di Riverpod, prova a utilizzarlo online su Dartpad o su Zapp:
Installazione del package
Una volta che sai quale pacchetto desideri installare, procedi ad aggiungere la dipendenza alla tua app tramite riga di comando:
- Flutter
- Dart only
flutter pub add flutter_riverpod
flutter pub add riverpod_annotation
flutter pub add dev:riverpod_generator
flutter pub add dev:build_runner
flutter pub add dev:custom_lint
flutter pub add dev:riverpod_lint
dart pub add riverpod
dart pub add riverpod_annotation
dart pub add dev:riverpod_generator
dart pub add dev:build_runner
dart pub add dev:custom_lint
dart pub add dev:riverpod_lint
In alternativa, puoi aggiungere manualmente la dipendenza alla tua app all'interno del tuo file pubspec.yaml
:
- Flutter
- Dart only
name: my_app_name
environment:
sdk: ">=3.0.0 <4.0.0"
flutter: ">=3.0.0"
dependencies:
flutter:
sdk: flutter
flutter_riverpod: ^2.6.1
riverpod_annotation: ^2.6.1
dev_dependencies:
build_runner:
custom_lint:
riverpod_generator: ^2.6.4
riverpod_lint: ^2.6.4
Infine, installa i package con flutter pub get
.
flutter pub run build_runner watch
.name: my_app_name
environment:
sdk: ">=3.0.0 <4.0.0"
dependencies:
riverpod: ^2.6.1
riverpod_annotation: ^2.6.1
dev_dependencies:
build_runner:
custom_lint:
riverpod_generator: ^2.6.4
riverpod_lint: ^2.6.4
Infine, installa i package con dart pub get
.
dart run build_runner watch
.Ecco fatto. Hai aggiunto Riverpod alla tua app!
Abilitare riverpod_lint/custom_lint
Riverpod include un pacchetto opzionale chiamato riverpod_lint che fornisce regole di lint per aiutarti a scrivere codice migliore e offre opzioni di refactoring personalizzate.
Il pacchetto dovrebbe già essere installato se hai seguito i passaggi precedenti, ma è necessario un passaggio separato per abilitarlo.
Per abilitare riverpod_lint, è necessario aggiungere un file analysis_options.yaml
posizionato sullo stesso livello del tuo pubspec.yaml
e includere quanto segue:
analyzer:
plugins:
- custom_lint
Ora dovresti vedere dei warning nel tuo ambiente di sviluppo (IDE) se hai commesso errori nell'utilizzo di Riverpod nel tuo codice.
Per vedere l'elenco completo dei possibili warning e refactoring, vai alla pagina di riverpod_lint.
Quei warning non verranno visualizzati nel comando dart analyze
.
Se desideri verificare tali warning in CI/terminale, puoi eseguire quanto segue:
dart run custom_lint
Esempio di utilizzo: Hello world
Ora che abbiamo installato Riverpod, possiamo iniziare ad usarlo.
Gli snippet seguenti mostrano come utilizzare la nostra nuova dipendenza per creare un "Hello world":
- Flutter
- Dart only
import 'package:flutter/material.dart';
import 'package:flutter_riverpod/flutter_riverpod.dart';
import 'package:riverpod_annotation/riverpod_annotation.dart';
part 'main.g.dart';
// We create a "provider", which will store a value (here "Hello world").
// By using a provider, this allows us to mock/override the value exposed.
String helloWorld(Ref ref) {
return 'Hello world';
}
void main() {
runApp(
// For widgets to be able to read providers, we need to wrap the entire
// application in a "ProviderScope" widget.
// This is where the state of our providers will be stored.
ProviderScope(
child: MyApp(),
),
);
}
// Extend ConsumerWidget instead of StatelessWidget, which is exposed by Riverpod
class MyApp extends ConsumerWidget {
Widget build(BuildContext context, WidgetRef ref) {
final String value = ref.watch(helloWorldProvider);
return MaterialApp(
home: Scaffold(
appBar: AppBar(title: const Text('Example')),
body: Center(
child: Text(value),
),
),
);
}
}
Successivamente, avvia l'applicazione con flutter run
.
Questo renderizzerà "Hello world" sul tuo dispositivo.
import 'package:riverpod/riverpod.dart';
import 'package:riverpod_annotation/riverpod_annotation.dart';
part 'main.g.dart';
// We create a "provider", which will store a value (here "Hello world").
// By using a provider, this allows us to mock/override the value exposed.
String helloWorld(Ref ref) {
return 'Hello world';
}
void main() {
// This object is where the state of our providers will be stored.
final container = ProviderContainer();
// Thanks to "container", we can read our provider.
final value = container.read(helloWorldProvider);
print(value); // Hello world
}
Successivamente, avvia l'applicazione con dart lib/main.dart
.
Vedrai stampato "Hello world" nella console.
Andando oltre: Installazione di snippet di codice
Se stai utilizzando Flutter
e VS Code
, considera l'utilizzo di Flutter Riverpod Snippets
Se stai utilizzando Flutter
e Android Studio
o IntelliJ
, considera l'utilizzo di Flutter Riverpod Snippets
Scegli il prossimo passo
Apprendi i concetti base:
Segui un cookbook: