Skip to content

Navigation Menu

Sign in
Appearance settings

Search code, repositories, users, issues, pull requests...

Provide feedback

We read every piece of feedback, and take your input very seriously.

Saved searches

Use saved searches to filter your results more quickly

Sign up
Appearance settings

A reactive caching and data-binding framework. Riverpod makes working with asynchronous code a breeze.

License

Notifications You must be signed in to change notification settings

SSakutaro/riverpod

Repository files navigation

Build Status codecov Star on Github License: MIT Discord

Deploys by Netlify

Riverpod


A reactive caching and data-binding framework. https://riverpod.dev Riverpod makes working with asynchronous code a breeze by:

  • Handling errors/loading states by default. No need to manually catch errors
  • Natively supporting advanced scenarios, such as pull-to-refresh
  • Separating the logic from your UI
  • Ensuring your code is testable, scalable and reusable
riverpod pub package
flutter_riverpod pub package
hooks_riverpod pub package

Welcome to Riverpod (anagram of Provider)!

For learning how to use Riverpod, see its documentation: >>> https://riverpod.dev <<<

Long story short:

  • Define network requests by writing a function annotated with @riverpod:

    @riverpod
    Future<String> boredSuggestion(Ref ref) async {
     final response = await http.get(
     Uri.https('boredapi.com', '/api/activity'),
     );
     final json = jsonDecode(response.body);
     return json['activity']! as String;
    }
  • Listen to the network request in your UI and gracefully handle loading/error states.

    class Home extends ConsumerWidget {
     @override
     Widget build(BuildContext context, WidgetRef ref) {
     final boredSuggestion = ref.watch(boredSuggestionProvider);
     // Perform a switch-case on the result to handle loading/error states
     return switch (boredSuggestion) {
     AsyncData(:final value) => Text('data: $value'),
     AsyncError(:final error) => Text('error: $error'),
     _ => const Text('loading'),
     };
     }
    }

Contributing

Contributions are welcome!

Here is a curated list of how you can help:

  • Report bugs and scenarios that are difficult to implement
  • Report parts of the documentation that are unclear
  • Fix typos/grammar mistakes
  • Update the documentation or add examples
  • Implement new features by making a pull-request

Sponsors

About

A reactive caching and data-binding framework. Riverpod makes working with asynchronous code a breeze.

Resources

License

Code of conduct

Contributing

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Dart 50.9%
  • MDX 46.9%
  • JavaScript 1.1%
  • TypeScript 1.0%
  • SCSS 0.1%
  • Shell 0.0%

AltStyle によって変換されたページ (->オリジナル) /