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

Flutter状态管理详解与最佳实践

Flutter状态管理详解与最佳实践什么是Flutter状态管理在Flutter应用中状态管理是指管理应用中数据的存储、更新和传递的过程。状态管理对于构建复杂的Flutter应用至关重要它可以帮助我们更好地组织代码提高应用的可维护性和可扩展性。状态管理的类型1. 临时状态临时状态是指只在单个widget中使用的状态不需要在多个widget之间共享。class CounterWidget extends StatefulWidget { override _CounterWidgetState createState() _CounterWidgetState(); } class _CounterWidgetState extends StateCounterWidget { int _counter 0; void _incrementCounter() { setState(() { _counter; }); } override Widget build(BuildContext context) { return Column( children: [ Text(Counter: $_counter), ElevatedButton( onPressed: _incrementCounter, child: Text(Increment), ), ], ); } }2. 应用状态应用状态是指需要在多个widget之间共享的状态如用户信息、主题设置等。状态管理方案1. setStatesetState是Flutter最基本的状态管理方式适用于简单的状态管理。优点使用简单适合小型应用不需要引入额外的依赖缺点状态管理逻辑与UI代码耦合不适合复杂的状态管理难以在多个widget之间共享状态2. InheritedWidgetInheritedWidget是Flutter提供的一种在widget树中传递数据的方式。class AppState extends InheritedWidget { final int counter; final Function() incrementCounter; const AppState({ Key? key, required this.counter, required this.incrementCounter, required Widget child, }) : super(key: key, child: child); static AppState of(BuildContext context) { final appState context.dependOnInheritedWidgetOfExactTypeAppState(); assert(appState ! null, No AppState found in context); return appState!; } override bool updateShouldNotify(AppState oldWidget) { return counter ! oldWidget.counter; } } // 使用 class MyApp extends StatefulWidget { override _MyAppState createState() _MyAppState(); } class _MyAppState extends StateMyApp { int _counter 0; void _incrementCounter() { setState(() { _counter; }); } override Widget build(BuildContext context) { return AppState( counter: _counter, incrementCounter: _incrementCounter, child: MaterialApp( home: HomePage(), ), ); } } class HomePage extends StatelessWidget { override Widget build(BuildContext context) { final appState AppState.of(context); return Scaffold( appBar: AppBar(title: Text(Home)), body: Center( child: Text(Counter: ${appState.counter}), ), floatingActionButton: FloatingActionButton( onPressed: appState.incrementCounter, child: Icon(Icons.add), ), ); } }优点可以在widget树中传递数据当数据变化时依赖该数据的widget会自动重建缺点需要手动实现状态管理逻辑代码较为复杂3. ProviderProvider是Flutter官方推荐的状态管理库基于InheritedWidget实现。安装dependencies: provider: ^6.0.0基本用法// 定义状态模型 class CounterModel extends ChangeNotifier { int _counter 0; int get counter _counter; void increment() { _counter; notifyListeners(); } } // 在main.dart中 void main() { runApp( ChangeNotifierProvider( create: (context) CounterModel(), child: MyApp(), ), ); } // 在widget中使用 class HomePage extends StatelessWidget { override Widget build(BuildContext context) { final counterModel Provider.ofCounterModel(context); return Scaffold( appBar: AppBar(title: Text(Home)), body: Center( child: Text(Counter: ${counterModel.counter}), ), floatingActionButton: FloatingActionButton( onPressed: counterModel.increment, child: Icon(Icons.add), ), ); } }优点使用简单代码清晰支持依赖注入适合中等复杂度的应用缺点对于非常复杂的应用可能需要更高级的状态管理方案4. RiverpodRiverpod是Provider的改进版提供了更灵活、更强大的状态管理能力。安装dependencies: flutter_riverpod: ^1.0.0基本用法// 定义provider final counterProvider StateProvider((ref) 0); // 在widget中使用 class HomePage extends ConsumerWidget { override Widget build(BuildContext context, WidgetRef ref) { final counter ref.watch(counterProvider); return Scaffold( appBar: AppBar(title: Text(Home)), body: Center( child: Text(Counter: $counter), ), floatingActionButton: FloatingActionButton( onPressed: () ref.read(counterProvider.notifier).state, child: Icon(Icons.add), ), ); } } // 在main.dart中 void main() { runApp( ProviderScope( child: MyApp(), ), ); }优点比Provider更灵活更强大支持依赖注入适合复杂的应用支持异步操作缺点学习曲线较陡5. BlocBloc是一种基于事件和状态的状态管理方案适合复杂的应用。安装dependencies: flutter_bloc: ^8.0.0基本用法// 定义事件 abstract class CounterEvent {} class IncrementEvent extends CounterEvent {} class DecrementEvent extends CounterEvent {} // 定义状态 class CounterState { final int counter; CounterState(this.counter); } // 定义Bloc class CounterBloc extends BlocCounterEvent, CounterState { CounterBloc() : super(CounterState(0)); override StreamCounterState mapEventToState(CounterEvent event) async* { if (event is IncrementEvent) { yield CounterState(state.counter 1); } else if (event is DecrementEvent) { yield CounterState(state.counter - 1); } } } // 在widget中使用 class HomePage extends StatelessWidget { override Widget build(BuildContext context) { return BlocProvider( create: (context) CounterBloc(), child: CounterView(), ); } } class CounterView extends StatelessWidget { override Widget build(BuildContext context) { return Scaffold( appBar: AppBar(title: Text(Home)), body: BlocBuilderCounterBloc, CounterState( builder: (context, state) { return Center( child: Text(Counter: ${state.counter}), ); }, ), floatingActionButton: Column( mainAxisAlignment: MainAxisAlignment.end, children: [ FloatingActionButton( onPressed: () context.readCounterBloc().add(IncrementEvent()), child: Icon(Icons.add), ), SizedBox(height: 10), FloatingActionButton( onPressed: () context.readCounterBloc().add(DecrementEvent()), child: Icon(Icons.remove),

相关文章:

Flutter状态管理详解与最佳实践

Flutter状态管理详解与最佳实践 什么是Flutter状态管理? 在Flutter应用中,状态管理是指管理应用中数据的存储、更新和传递的过程。状态管理对于构建复杂的Flutter应用至关重要,它可以帮助我们更好地组织代码,提高应用的可维护性和…...

CSS变量详解与应用

CSS变量详解与应用 什么是CSS变量? CSS变量(也称为自定义属性)是CSS3引入的一种机制,允许我们定义可重用的值,这些值可以在整个样式表中使用。CSS变量为我们提供了一种更灵活、更可维护的方式来管理样式。 基本语法 定…...

从零构建ARM64嵌入式Linux:内核裁剪与最小根文件系统实践

1. ARM64嵌入式Linux开发环境搭建 在开始构建ARM64嵌入式Linux系统之前,我们需要准备一个合适的开发环境。我建议使用Ubuntu 20.04 LTS作为开发主机系统,因为这个版本有很好的软件包支持和社区资源。 首先安装必要的交叉编译工具链: sudo …...

Chart.js 3.9.1 最新版安装与配置全攻略(含CDN和npm两种方式)

Chart.js 3.9.1 最新版安装与配置全攻略(含CDN和npm两种方式) 如果你正在寻找一个轻量级、功能强大的JavaScript图表库来为你的项目添加可视化元素,Chart.js绝对值得考虑。这个开源库以其简洁的API和丰富的图表类型赢得了全球开发者的青睐。…...

C++计算器避坑指南:处理大数阶乘、浮点精度和非法输入的那些坑

C计算器避坑指南:处理大数阶乘、浮点精度和非法输入的那些坑 在开发C计算器的过程中,我们常常会遇到一些看似简单却暗藏玄机的问题。从大数阶乘导致的整数溢出,到浮点数运算的精度陷阱,再到用户输入的千奇百怪格式,每一…...

【开源】Vue拖拽表单设计器实战:从零构建自定义表单系统

1. 为什么需要拖拽表单设计器 表单是Web开发中最常见的交互元素之一,从简单的登录注册到复杂的数据收集场景都离不开它。传统开发方式中,每次新增一个表单都需要前端手动编写大量模板代码,后端配置校验规则,这种重复劳动不仅效率低…...

原生实现Web百度离线地图:从配置到展示全流程解析

1. 为什么需要离线地图? 最近接手了一个政府单位的内部管理系统项目,客户明确要求地图功能必须支持离线环境。这让我意识到,在很多特殊场景下,离线地图确实是刚需。比如在偏远地区网络信号不稳定时,或者某些涉密项目不…...

2026届最火的十大降重复率助手推荐榜单

Ai论文网站排名(开题报告、文献综述、降aigc率、降重综合对比) TOP1. 千笔AI TOP2. aipasspaper TOP3. 清北论文 TOP4. 豆包 TOP5. kimi TOP6. deepseek 用户输入论文主题或者关键词,DeepSeek作为智能写作工具,就能自动生成…...

创建Controller HTTP测试脚本

创建Controller HTTP测试脚本 任务概述 为fastbee-open-api模块下的103个Controller创建对应的HTTP测试脚本文件,确保测试覆盖所有主要接口。 测试脚本规范 文件格式 文件名: {ControllerName}.http (如: DeviceController.http, SysUserController.http)存放位置: f:/project/…...

NDK开发实战:从C/C++到高性能Android应用的关键技术解析

1. 为什么需要NDK开发? 很多Android开发者刚开始接触NDK时都会有这样的疑问:Java和Kotlin已经这么强大了,为什么还要折腾C/C?这个问题我在2014年第一次接触NDK时也思考过很久。经过这些年的实战,我发现NDK在以下场景中…...

SQL统计各分组中排名前三的记录_使用窗口函数RANK

RANK() 遇相同值并列且跳号,如三个第1名后直接第4名;若仅用 WHERE rank ≤ 3 过滤,会漏掉并列第3名之后实际应入选的并列名次,导致结果偏少而非偏多——题干“多出几条”通常源于误将 RANK() 与 ROW_NUMBER() 混淆或未正确处理分组…...

Phi-3 Forest Laboratory跨学科知识融合效果:解释STM32开发与Matlab仿真概念

Phi-3 Forest Laboratory跨学科知识融合效果:解释STM32开发与Matlab仿真概念 最近在试用Phi-3 Forest Laboratory这个模型,它有个特点让我印象挺深的,就是能把不同领域的知识串起来讲,讲得还挺明白。这有点像你身边那个“什么都懂…...

【数据结构与算法】第46篇:算法思想(一):递归与分治

一、递归的本质 1.1 什么是递归 递归就是函数调用自身。一个递归函数通常包含两部分&#xff1a; 终止条件&#xff1a;什么时候停止递归 递推公式&#xff1a;如何将大问题转化为小问题 c // 阶乘的递归实现 int factorial(int n) {if (n < 1) return 1; // 终…...

易盾滑块验证码v2.27.2的fp参数生成:从环境补全到完整算法扣取(附200行代码解析)

易盾滑块验证码v2.27.2的fp参数深度解析&#xff1a;从环境模拟到算法还原实战 最近在分析某主流验证码服务商的最新版本时&#xff0c;发现其fp参数生成机制有了显著变化。作为前端安全防护的核心环节&#xff0c;指纹参数(fp)的生成质量直接决定了验证码系统的防御能力。本文…...

从微信对话到数字遗产:WeChatMsg让您的聊天记忆永久留存

从微信对话到数字遗产&#xff1a;WeChatMsg让您的聊天记忆永久留存 【免费下载链接】WeChatMsg 提取微信聊天记录&#xff0c;将其导出成HTML、Word、CSV文档永久保存&#xff0c;对聊天记录进行分析生成年度聊天报告 项目地址: https://gitcode.com/GitHub_Trending/we/WeC…...

【组合实战】OCR + 图片去水印 API:自动清洗图片再识别文字(完整方案 + 代码示例)

【组合实战】OCR 图片去水印 API&#xff1a;自动清洗图片再识别文字&#xff08;完整方案 代码示例&#xff09; 在实际业务中&#xff0c;很多图片并不是“干净”的&#xff1a; &#x1f449; 带水印、遮挡、广告、LOGO、二维码…… 直接做 OCR 识别&#xff0c;往往会…...

Oracle11G表空间数据文件扩容实战:突破32G限制的解决方案

1. 为什么Oracle11G会有32G数据文件限制 很多刚接触Oracle数据库的朋友第一次遇到表空间无法扩容时都会懵——明明磁盘空间充足&#xff0c;为什么提示"无法扩展数据文件"&#xff1f;这个问题的根源在于Oracle11G的物理存储机制。我十年前第一次在生产环境碰到这个问…...

智能体评测基础:能力、稳定性、安全性评估标准

文章目录前言一、智能体评测&#xff1a;为什么传统方法彻底失效&#xff1f;1.1 智能体 vs 传统软件&#xff1a;本质差异1.2 2026年智能体评测的核心原则&#xff08;行业标准&#xff09;1.3 评测的三层核心目标&#xff08;2026 CLASSic框架&#xff09;二、能力评估&#…...

大模型底层逻辑:RAG 检索增强生成

大模型有一个致命的弱点&#xff1a;知识滞后。它的知识停留在训练结束的那一天&#xff08;训练剪裁期&#xff09;。如果你问它“今天早上的天气预报”或者“你们公司的最新报销政策”&#xff0c;它只会一本正经地胡说八道&#xff08;幻觉&#xff09;。RAG (Retrieval-Aug…...

如何在云主机上安装Oracle 19c_公网IP绑定与安全组端口开放

Oracle 19c 连不上需依次检查&#xff1a;监听是否绑定公网IP&#xff08;修改listener.ora中HOST为0.0.0.0或公网IP并lsnrctl reload&#xff09;、系统防火墙是否放行1521端口、tnsnames.ora中HOST地址匹配客户端网络位置&#xff08;公网/内网&#xff09;、以及listener.or…...

SRS GB28181接入实战:除了海康摄像头,你的NVR和第三方IPC怎么配?附API调用初探

SRS GB28181多设备接入实战&#xff1a;从NVR到第三方IPC的配置与API控制 监控设备集成领域的技术人员经常面临一个现实挑战&#xff1a;如何在同一个GB28181服务器上兼容不同厂商的设备&#xff1f;上周我帮某连锁超市部署集中监控系统时&#xff0c;就遇到了大华NVR与宇视IPC…...

为什么92%的电商多模态搜索项目止步POC?SITS2026给出3个硬核交付标准

第一章&#xff1a;SITS2026案例&#xff1a;电商多模态搜索应用 2026奇点智能技术大会(https://ml-summit.org) 在SITS2026技术实践赛道中&#xff0c;某头部电商平台基于多模态大模型构建了新一代商品搜索系统&#xff0c;支持文本、图像、草图及语音混合输入&#xff0c;并…...

你项目中 RAG 的存储架构是怎么设计的?

1. 题目分析RAG 系统里最容易被低估的就是存储层。很多人把 RAG 理解成"文档切片→扔进向量库→检索→喂给 LLM"的线性流水线&#xff0c;存储仿佛只是中间一个"放东西的地方"。但真正做过生产级 RAG 的人都知道&#xff0c;存储架构的设计深度远超一个向量…...

2026年怎么安装OpenClaw?华为云7分钟喂饭级流程+大模型APIKey配置、Skill集成流程

2026年怎么安装OpenClaw&#xff1f;华为云7分钟喂饭级流程大模型APIKey配置、Skill集成流程。本文面向零基础用户&#xff0c;完整说明在轻量服务器与本地Windows11、macOS、Linux系统中部署OpenClaw&#xff08;Clawdbot&#xff09;的流程&#xff0c;包含环境配置、服务启动…...

魔兽争霸3终极兼容性修复:5大核心功能彻底解决90%游戏问题

魔兽争霸3终极兼容性修复&#xff1a;5大核心功能彻底解决90%游戏问题 【免费下载链接】WarcraftHelper Warcraft III Helper , support 1.20e, 1.24e, 1.26a, 1.27a, 1.27b 项目地址: https://gitcode.com/gh_mirrors/wa/WarcraftHelper 还在为魔兽争霸3启动闪退、画面…...

ROS牛耕法全覆盖规划:从算法原理到清洁机器人实战解析

1. ROS牛耕法全覆盖规划算法初探 第一次接触牛耕法&#xff08;Boustrophedon&#xff09;这个词时&#xff0c;我还以为是某种农业机械的控制方法。后来在开发清洁机器人路径规划时才发现&#xff0c;这其实是ROS中最经典的全覆盖路径规划算法之一。想象一下老黄牛在田里来回耕…...

**发散创新:基于Solid协议的Web3.0去中心化身份认证系统实战

发散创新&#xff1a;基于Solid协议的Web3.0去中心化身份认证系统实战解析 在Web3.0时代&#xff0c;用户数据不再由中心化平台掌控&#xff0c;而是通过区块链与去中心化存储技术实现自主权。其中&#xff0c;去中心化身份&#xff08;DID&#xff09; 成为构建可信数字身份体…...

**WebUSB实战:从浏览器直连硬件到自动化设备控制的突破性应用**

WebUSB实战&#xff1a;从浏览器直连硬件到自动化设备控制的突破性应用 在现代Web开发中&#xff0c;越来越多的应用场景要求浏览器能够直接与物理设备通信。传统方式依赖于原生客户端&#xff08;如Java Applet、ActiveX控件&#xff09;或第三方驱动程序&#xff0c;但这些方…...

如何利用ViGEmBus虚拟手柄驱动实现Windows游戏控制器完美兼容

如何利用ViGEmBus虚拟手柄驱动实现Windows游戏控制器完美兼容 【免费下载链接】ViGEmBus Windows kernel-mode driver emulating well-known USB game controllers. 项目地址: https://gitcode.com/gh_mirrors/vi/ViGEmBus 想要让非标准游戏手柄在Windows系统中获得原生…...

HJ177 可匹配子段计数

知识点双指针 校招时部分企业笔试将禁止编程题跳出页面&#xff0c;为提前适应&#xff0c;练习时请使用在线自测&#xff0c;而非本地IDE。 描述 给定整数数组 aa&#xff08;长度 nn&#xff09;与数组 bb&#xff08;长度 mm&#xff0c;m≦nm≦n&#xff09;。设一个长度…...