当前位置: 首页 > article >正文

Flutter Riverpod:状态管理的新纪元

Flutter Riverpod状态管理的新纪元告别 Provider 的繁琐拥抱 Riverpod 的简洁与强大。一、为什么选择 Riverpod作为一名追求代码如散文般优雅的 UI 匠人我对状态管理工具有着近乎偏执的要求。Riverpod 不仅解决了 Provider 的上下文依赖问题还带来了编译时安全、代码生成和更好的测试性。这就像从手动调音的钢琴换成了自动校准的演奏级三角钢琴。二、基础概念1. Provider 类型import package:flutter_riverpod/flutter_riverpod.dart; // 简单值 final nameProvider ProviderString((ref) Leopold); // 状态管理 final counterProvider StateProviderint((ref) 0); // 异步数据 final userProvider FutureProviderUser((ref) async { final response await http.get(Uri.parse(/api/user)); return User.fromJson(jsonDecode(response.body)); }); // 计算属性 final greetingProvider ProviderString((ref) { final name ref.watch(nameProvider); return Hello, $name!; });2. ConsumerWidget 使用class CounterPage extends ConsumerWidget { override Widget build(BuildContext context, WidgetRef ref) { final count ref.watch(counterProvider); return Scaffold( appBar: AppBar(title: Text(Counter)), body: Center( child: Text( $count, style: Theme.of(context).textTheme.headlineLarge, ), ), floatingActionButton: FloatingActionButton( onPressed: () ref.read(counterProvider.notifier).state, child: Icon(Icons.add), ), ); } }三、高级用法1. StateNotifier 复杂状态class Todo { final String id; final String title; final bool isCompleted; Todo({ required this.id, required this.title, this.isCompleted false, }); Todo copyWith({String? title, bool? isCompleted}) { return Todo( id: id, title: title ?? this.title, isCompleted: isCompleted ?? this.isCompleted, ); } } class TodoNotifier extends StateNotifierListTodo { TodoNotifier() : super([]); void addTodo(String title) { state [ ...state, Todo( id: DateTime.now().toString(), title: title, ), ]; } void toggleTodo(String id) { state state.map((todo) { if (todo.id id) { return todo.copyWith(isCompleted: !todo.isCompleted); } return todo; }).toList(); } void removeTodo(String id) { state state.where((todo) todo.id ! id).toList(); } } final todoProvider StateNotifierProviderTodoNotifier, ListTodo((ref) { return TodoNotifier(); });2. 依赖注入final apiClientProvider ProviderApiClient((ref) { return ApiClient(baseUrl: https://api.example.com); }); final userRepositoryProvider ProviderUserRepository((ref) { final apiClient ref.watch(apiClientProvider); return UserRepository(apiClient); }); final userListProvider FutureProviderListUser((ref) async { final repository ref.watch(userRepositoryProvider); return repository.getUsers(); });3. 自动刷新与缓存final autoDisposeProvider FutureProvider.autoDisposeListPost((ref) async { // 当不再被监听时自动释放 final response await http.get(Uri.parse(/api/posts)); return jsonDecode(response.body); }); // 带缓存策略 final cachedProvider FutureProviderListPost((ref) async { // 保持 5 分钟缓存 final link ref.keepAlive(); Timer(Duration(minutes: 5), link.close); final response await http.get(Uri.parse(/api/posts)); return jsonDecode(response.body); });四、实战案例主题切换final themeModeProvider StateProviderThemeMode((ref) ThemeMode.system); class ThemeSwitcher extends ConsumerWidget { override Widget build(BuildContext context, WidgetRef ref) { final themeMode ref.watch(themeModeProvider); return DropdownButtonThemeMode( value: themeMode, onChanged: (value) { if (value ! null) { ref.read(themeModeProvider.notifier).state value; } }, items: [ DropdownMenuItem( value: ThemeMode.light, child: Text(浅色模式), ), DropdownMenuItem( value: ThemeMode.dark, child: Text(深色模式), ), DropdownMenuItem( value: ThemeMode.system, child: Text(跟随系统), ), ], ); } } // 在 MaterialApp 中使用 class MyApp extends ConsumerWidget { override Widget build(BuildContext context, WidgetRef ref) { final themeMode ref.watch(themeModeProvider); return MaterialApp( themeMode: themeMode, theme: ThemeData.light(), darkTheme: ThemeData.dark(), home: HomePage(), ); } }五、最佳实践单一职责每个 Provider 只做一件事依赖注入通过 Provider 传递依赖便于测试自动释放使用 autoDispose 避免内存泄漏错误处理始终处理异步操作的错误状态状态是应用的脉搏Riverpod 让脉搏跳动得更有韵律。#flutter #riverpod #state-management #dart #architecture

相关文章:

Flutter Riverpod:状态管理的新纪元

Flutter Riverpod:状态管理的新纪元告别 Provider 的繁琐,拥抱 Riverpod 的简洁与强大。一、为什么选择 Riverpod? 作为一名追求代码如散文般优雅的 UI 匠人,我对状态管理工具有着近乎偏执的要求。Riverpod 不仅解决了 Provider 的…...

CSS Subgrid:网格布局的终极进化

CSS Subgrid:网格布局的终极进化当 Grid 遇见 Subgrid,嵌套布局终于有了完美的解决方案。一、Subgrid 解决了什么问题? 作为一名追求像素级还原的 UI 匠人,我深知嵌套网格的痛苦——子元素的网格线永远对不齐父元素,就…...

UI 动效设计原则:让界面呼吸起来

UI 动效设计原则:让界面呼吸起来 动效不是装饰,而是交互的语言。掌握这些原则,让你的设计会"说话"。 一、动效的本质 作为一名把代码当散文写的 UI 匠人,我始终认为动效是界面的灵魂。一个好的动效应该像呼吸一样自然—…...

CSS Scroll Snap:打造丝滑滚动体验

CSS Scroll Snap:打造丝滑滚动体验让滚动不再是粗暴的跳跃,而是优雅的吸附。CSS Scroll Snap 让页面流动如丝绸般顺滑。一、为什么需要 Scroll Snap? 作为一名追求像素级还原的 UI 匠人,我深知一个粗糙的滚动体验能瞬间毁掉精心设…...

Flutter CustomPainter:绘制你的视觉诗篇

Flutter CustomPainter:绘制你的视觉诗篇当 Flutter 的 widget 无法满足你的艺术追求时,CustomPainter 让你成为画布的主人。一、为什么要用 CustomPainter? 作为一名追求像素级还原的 UI 匠人,我深知标准组件的局限。有时候&…...

终极团队协作利器:Synthwave ‘84主题如何实现多人开发环境一致性

终极团队协作利器:Synthwave 84主题如何实现多人开发环境一致性 【免费下载链接】synthwave-vscode Synthwave inspired colour theme for VS Code 🌅🕶 项目地址: https://gitcode.com/gh_mirrors/sy/synthwave-vscode 在现代软件开…...

Thrust安全最佳实践:保护你的桌面应用免受安全威胁

Thrust安全最佳实践:保护你的桌面应用免受安全威胁 【免费下载链接】thrust Chromium-based cross-platform / cross-language application framework 项目地址: https://gitcode.com/gh_mirrors/thru/thrust Thrust作为基于Chromium的跨平台应用框架&#x…...

如何用Bubblewrap CLI创建你的第一个Trusted Web Activity项目

如何用Bubblewrap CLI创建你的第一个Trusted Web Activity项目 【免费下载链接】bubblewrap Bubblewrap is a Command Line Interface (CLI) that helps developers to create a Project for an Android application that launches an existing Progressive Web App (PWAs) usi…...

基于MATLAB的轮轨接触几何计算GUI程序设计与实现

1-148 matlab的带有gui的轮轨接触几何计算程序基于matlab的带有gui的轮轨接触几何计算程序,根据不同的踏面和轨头,计算不同横移量下面的接触点位置。程序已调通,可直接运行有没有人蹲过现成的、换文件就能换轮轨、不用啃半天赫兹接触前的几何方程、结果还…...

突破手游操控瓶颈:QtScrcpy虚拟映射技术全解析

突破手游操控瓶颈:QtScrcpy虚拟映射技术全解析 【免费下载链接】QtScrcpy Android real-time display control software 项目地址: https://gitcode.com/GitHub_Trending/qt/QtScrcpy 在移动游戏蓬勃发展的今天,触控操作的局限性日益凸显。竞技类…...

Seesaw v2直接服务器返回(DSR)模式配置教程:提升负载均衡性能的终极指南

Seesaw v2直接服务器返回(DSR)模式配置教程:提升负载均衡性能的终极指南 【免费下载链接】seesaw Seesaw v2 is a Linux Virtual Server (LVS) based load balancing platform. 项目地址: https://gitcode.com/gh_mirrors/see/seesaw Seesaw v2是基于Linux V…...

SystemBarTint终极贡献指南:如何快速参与这个Android系统栏着色开源项目

SystemBarTint终极贡献指南:如何快速参与这个Android系统栏着色开源项目 【免费下载链接】SystemBarTint [DEPRECATED] Apply background tinting to the Android system UI when using KitKat translucent modes 项目地址: https://gitcode.com/gh_mirrors/sy/Sy…...

现代化前端架构设计的10个黄金原则:从Este项目学习最佳实践

现代化前端架构设计的10个黄金原则:从Este项目学习最佳实践 【免费下载链接】este This repo is suspended. 项目地址: https://gitcode.com/gh_mirrors/es/este 在当今快速发展的前端开发领域,构建可维护、可扩展且高效的应用程序架构至关重要。…...

构建高效用户行为分析系统:Este全栈应用监控与性能追踪终极指南

构建高效用户行为分析系统:Este全栈应用监控与性能追踪终极指南 【免费下载链接】este This repo is suspended. 项目地址: https://gitcode.com/gh_mirrors/es/este 在当今快速发展的应用开发领域,用户行为分析系统和应用性能监控已成为每个成功…...

FreeGPT WebUI提供商开发终极教程:如何快速构建自定义AI服务

FreeGPT WebUI提供商开发终极教程:如何快速构建自定义AI服务 【免费下载链接】freegpt-webui GPT 3.5/4 with a Chat Web UI. No API key required. 项目地址: https://gitcode.com/gh_mirrors/fr/freegpt-webui FreeGPT WebUI是一个开源项目,让你…...

Bowser插件开发终极指南:如何创建可复用的浏览器检测组件

Bowser插件开发终极指南:如何创建可复用的浏览器检测组件 【免费下载链接】bowser a browser detector 项目地址: https://gitcode.com/gh_mirrors/bo/bowser Bowser是一个轻量级、高性能的浏览器检测库,专门用于识别用户浏览器、操作系统和平台信…...

yaml-cpp性能基准测试全解析:C++ YAML解析器速度与内存占用深度分析

yaml-cpp性能基准测试全解析:C YAML解析器速度与内存占用深度分析 【免费下载链接】yaml-cpp A YAML parser and emitter in C 项目地址: https://gitcode.com/gh_mirrors/ya/yaml-cpp yaml-cpp是一个功能强大的C YAML解析器和发射器库,它完全遵循…...

终极指南:AngularJS UI-Router 路由历史管理与导航栈实现详解

终极指南:AngularJS UI-Router 路由历史管理与导航栈实现详解 【免费下载链接】ui-router The de-facto solution to flexible routing with nested views in AngularJS 项目地址: https://gitcode.com/gh_mirrors/ui/ui-router AngularJS UI-Router 是 Angu…...

终极指南:Cert-Manager事件溯源实现与审计追踪全解析

终极指南:Cert-Manager事件溯源实现与审计追踪全解析 【免费下载链接】cert-manager Automatically provision and manage TLS certificates in Kubernetes 项目地址: https://gitcode.com/gh_mirrors/ce/cert-manager Cert-Manager作为Kubernetes生态中自动…...

如何用UI-Router构建复杂的AngularJS多视图应用:终极状态管理指南

如何用UI-Router构建复杂的AngularJS多视图应用:终极状态管理指南 【免费下载链接】ui-router The de-facto solution to flexible routing with nested views in AngularJS 项目地址: https://gitcode.com/gh_mirrors/ui/ui-router UI-Router是AngularJS中最…...

Zellij远程认证终极指南:OAuth、SSH与令牌管理全解析

Zellij远程认证终极指南:OAuth、SSH与令牌管理全解析 【免费下载链接】zellij A terminal workspace with batteries included 项目地址: https://gitcode.com/gh_mirrors/ze/zellij 欢迎来到Zellij终端工作区的远程认证世界!🚀 Zelli…...

终极指南:Nativefier 构建代理环境变量优先级与冲突解决方案

终极指南:Nativefier 构建代理环境变量优先级与冲突解决方案 【免费下载链接】nativefier Make any web page a desktop application 项目地址: https://gitcode.com/gh_mirrors/na/nativefier Nativefier 是一款强大的工具,能够将任何网页转换为…...

UID生成器终极路线图:未来版本将带来的7大突破性功能

UID生成器终极路线图:未来版本将带来的7大突破性功能 【免费下载链接】uid-generator UniqueID generator 项目地址: https://gitcode.com/gh_mirrors/ui/uid-generator UID生成器是分布式系统中确保数据唯一性的核心组件,GitHub加速计划下的ui/u…...

如何为Rust GUI应用添加无障碍支持:Iced屏幕阅读器与键盘导航实现指南

如何为Rust GUI应用添加无障碍支持:Iced屏幕阅读器与键盘导航实现指南 【免费下载链接】iced A cross-platform GUI library for Rust, inspired by Elm 项目地址: https://gitcode.com/GitHub_Trending/ic/iced Iced是一个受Elm启发的跨平台Rust GUI库&…...

Serde JSON Map对象终极指南:BTreeMap与IndexMap性能深度对比

Serde JSON Map对象终极指南:BTreeMap与IndexMap性能深度对比 【免费下载链接】json Strongly typed JSON library for Rust 项目地址: https://gitcode.com/gh_mirrors/jso/json Serde JSON 是 Rust 生态中最流行的 JSON 序列化库,提供了强大的类…...

LLMLingua未来展望:AI推理加速技术的终极发展趋势

LLMLingua未来展望:AI推理加速技术的终极发展趋势 【免费下载链接】LLMLingua [EMNLP23, ACL24] To speed up LLMs inference and enhance LLMs perceive of key information, compress the prompt and KV-Cache, which achieves up to 20x compression with minima…...

终极指南:Kubernetes云原生生态与CNCF项目集成实战

终极指南:Kubernetes云原生生态与CNCF项目集成实战 【免费下载链接】kubernetes-handbook Kubernetes Handbook (Kubernetes指南) https://kubernetes.feisky.xyz 项目地址: https://gitcode.com/gh_mirrors/kub/kubernetes-handbook …...

Automerge 数据备份与恢复终极指南:10个关键策略保护你的协作数据

Automerge 数据备份与恢复终极指南:10个关键策略保护你的协作数据 【免费下载链接】automerge A JSON-like data structure (a CRDT) that can be modified concurrently by different users, and merged again automatically. 项目地址: https://gitcode.com/gh…...

AWS容器扩展性终极指南:如何构建可伸缩的容器化应用

AWS容器扩展性终极指南:如何构建可伸缩的容器化应用 【免费下载链接】containers-roadmap This is the public roadmap for AWS container services (ECS, ECR, Fargate, and EKS). 项目地址: https://gitcode.com/gh_mirrors/co/containers-roadmap 在当今…...

Go语言macdriver性能基准测试:与其他macOS开发方案的终极对比分析

Go语言macdriver性能基准测试:与其他macOS开发方案的终极对比分析 【免费下载链接】macdriver Native Mac APIs for Go. Previously known as MacDriver 项目地址: https://gitcode.com/gh_mirrors/ma/macdriver 在macOS原生应用开发领域,选择合适…...