flutter 常见的状态管理器

flutter 常见的状态管理器

  • 前言
  • 一、Provider
  • 二、Bloc
  • 三、Redux
  • 四、GetX
  • 总结


前言

在这里插入图片描述

当我们构建复杂的移动应用时,有效的状态管理是至关重要的,因为应用的不同部分可能需要共享数据、相应用户交互并保持一致的状态。Flutter 中有多种状态管理解决方案,下面详细介绍一些常见的状态管理方式:Provider、Bloc 和 Redux、getx 等等一些管理工具。


一、Provider

Provider: Provider 是 Flutter 社区广泛使用的状态管理库,它使用了 InheritedWidget 和 ChangeNotifier 的概念来实现状态共享和更新。Provider 适用于中小型应用或对于简单状态共享的情况。

  • InheritedWidget: InheritedWidget 是 Flutter 中的一种特殊的小部件,允许其子部件在其上方访问共享数据。
  • ChangeNotifier: ChangeNotifier 是一个基类,可以帮助我们实现“可观察”的对象,它包含了状态并通知监听者当状态发生改变。

Provider 的工作原理是将数据模型(Model)包装在 ChangeNotifierProvider 中,然后通过 Consumer 或 Provider.of 来访问和监听状态变化。这种方式适用于相对简单的状态管理需求,如表单数据、主题等。

二、Bloc

Bloc(Business Logic Component): Bloc 是一种状态管理模式,专注于将业务逻辑从 UI 层分离出来。Bloc 模式建议将应用程序的状态、事件和业务逻辑分离开来,使应用更容易维护和测试。

  • States: 状态表示应用程序的不同状态,如加载中、成功、失败等。
  • Events: 事件表示用户操作或应用内的触发动作,例如按钮点击、数据请求等。
  • Bloc: Bloc 将状态和事件联系起来,根据事件的发生来改变状态。

Bloc 模式通常与第三方库 flutter_bloc 一起使用,该库提供了 BlocProviderBlocBuilder 等小部件来简化状态管理。

三、Redux

Redux: Redux 是一种通用的状态管理模式,最初用于 Web 应用,但也在 Flutter 中得到广泛应用。Redux 的核心思想是将应用的状态存储在一个全局的状态存储容器中,状态只能通过派发动作(Actions)来修改,从而实现单一数据源、可预测的状态变化。

  • Store: 全局的状态存储容器,保存应用的状态。
  • Actions: 表示状态的变化,需要一个类型和一些数据。
  • Reducers: 根据接收到的 Action,更新状态并返回新的状态。
  • Selectors: 用于从状态中选择特定的数据。

在 Flutter 中使用 Redux 需要使用第三方库,如 flutter_redux,该库提供了用于连接 Flutter 应用和 Redux Store 的小部件。

四、GetX

GetX 是一个在 Flutter 中提供状态管理和依赖注入的强大工具包。它为开发者提供了一种简单、高效的方式来管理应用程序的状态和依赖关系。下面让我们详细讲解一下 GetX 的状态管理器部分。

  1. 状态管理:

在 GetX 中,状态管理使用了名为 Rx 的类来表示可观察的数据。Rx 类是 GetX 的核心概念之一,它允许你将数据转换为可被监听的流,并且可以在数据发生变化时通知观察者。以下是一些重要的 Rx 类:

RxInt, RxDouble, RxString, …: 用于表示整数、浮点数、字符串等类型的可观察数据。
RxList, RxSet, RxMap: 用于表示集合类型的可观察数据。
RxBool: 用于表示布尔类型的可观察数据。
RxNotifier: 用于自定义对象的可观察数据。
dart

// 示例:使用 RxInt
final count = RxInt(0);// 监听数据变化
ever(count, (value) {print('Count changed to $value');
});// 更新数据
count.value++;
  1. 状态更新:

使用 GetX 更新状态非常简单。你可以直接通过 .value 属性来更新可观察数据的值。GetX 会自动通知订阅了该数据的观察者。

final count = RxInt(0);// 更新数据
count.value++; // 通知观察者数据变化
  1. 依赖注入:

GetX 也提供了依赖注入的功能,使得在应用中的不同部分共享实例变得容易。你可以使用 Get.put() 方法来注册实例,并且使用 Get.find() 来获取已注册的实例。

class MyController extends GetxController {// Your controller code
}// 注册控制器实例
Get.put(MyController());// 获取实例
MyController myController = Get.find<MyController>();
  1. GetBuilder 和 Obx:

GetBuilder: 这是一个小部件,它可以根据可观察数据的变化来重建部件树。你可以使用 GetBuilder 将小部件与可观察数据关联,使其在数据变化时自动重建。
Obx: 这是一个更轻量级的小部件,适用于只需要监听一个可观察数据的情况。你可以通过 Obx(() => YourWidget()) 的方式来实现。
5. 其他功能:

GetX 还提供了很多其他有用的功能,如路由管理、导航、国际化等,使得开发过程更加高效。你可以通过 Get.to() 和 Get.off() 等方法来进行页面导航,通过 Get.putAsync() 来异步注册依赖项等。


总结

无论选择哪种状态管理方式,都需要根据应用的规模、复杂性和开发团队的偏好来做出决定。这些状态管理模式的核心目标是有效地管理应用的状态,使代码结构清晰、易于维护,并提供良好的开发体验。

总体来说,GetX 是一个功能强大且易于学习的状态管理和依赖注入工具包,适用于各种规模和复杂度的 Flutter 应用程序。它的简洁语法和高性能使得开发者可以更专注于业务逻辑,而无需过多关注状态管理的细节。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/39322.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

0143 串

目录 4.串 4.1串的定义和实现 4.2串的模式匹配 部分习题 4.串 4.1串的定义和实现 4.2串的模式匹配 部分习题 1.设有两个串S1和S2&#xff0c;求S2在S1中首次出现的位置的运算称为&#xff08;&#xff09; A.求字串 B.判断是否相等 C.模式匹配 D.连…

Vue2(组件开发)

目录 前言一&#xff0c;组件的使用二&#xff0c;插槽slot三&#xff0c;refs和parent四&#xff0c;父子组件间的通信4.1&#xff0c;父传子 &#xff1a;父传子的时候&#xff0c;通过属性传递4.2&#xff0c;父组件监听自定义事件 五&#xff0c;非父子组件的通信六&#x…

麦肯锡发布《2023年度科技报告》!

在经历了 2022 年技术投资和人才的动荡之后&#xff0c;2023 年上半年&#xff0c;人们对技术促进商业和社会进步的潜力重新燃起了热情。生成式人工智能&#xff08;Generative AI&#xff09;在这一复兴过程中功不可没&#xff0c;但它只是众多进步中的一个&#xff0c;可以推…

总说绿幕直播抠像抠不干净?很有可能是你不知道这个神器!

在绿幕直播的时候&#xff0c;你是不是座位、绿幕、灯光都摆对了&#xff0c;但主播轮廓仍然有绿边和虚化的情况发生&#xff1f;这种很大可能就是你使用的直播抠像软件有问题。今天小编把市面上的常见直播软件来和vLive虚拟直播的抠像做一个对比&#xff0c;让你直观感受下他们…

机器学习笔记 - 基于PyTorch + 类似ResNet的单目标检测

一、获取并了解数据 我们将处理年龄相关性黄斑变性 (AMD) 患者的眼部图像。 数据集下载地址,从下面的地址中,找到iChallenge-AMD,然后下载。 Baidu Research Open-Access Dataset - DownloadDownload Baidu Research Open-Access Datasethttps://ai.baidu.com/bro…

基于ACF,AMDF算法的语音编码matlab仿真

目录 1.算法运行效果图预览 2.算法运行软件版本 3.部分核心程序 4.算法理论概述 5.算法完整程序工程 1.算法运行效果图预览 2.算法运行软件版本 matlab2022a 3.部分核心程序 .......................................................................... plotFlag …

函数递归专题(案例超详解一篇讲通透)

函数递归 前言1.递归案例:案例一&#xff1a;取球问题案例二&#xff1a;求斐波那契额数列案例三&#xff1a;函数实现n的k次方案例四&#xff1a;输入一个非负整数&#xff0c;返回组成它的数字之和案例五&#xff1a;元素逆置案例六&#xff1a;实现strlen案例七&#xff1a;…

服务器遭受攻击之后的常见思路

哈喽大家好&#xff0c;我是咸鱼 不知道大家有没有看过这么一部电影&#xff1a; 这部电影讲述了男主是一个电脑极客&#xff0c;在计算机方面有着不可思议的天赋&#xff0c;男主所在的黑客组织凭借着超高的黑客技术去入侵各种国家机构的系统&#xff0c;并引起了德国秘密警察…

Mac如何打开隐藏文件中Redis的配置文件redis.conf

Redis下载(通过⬇️博客下载的Redis默认路径为&#xff1a;/usr/local/etc) Redis下载 1.打开终端进入/usr文件夹 cd /usr 2.打开/local/文件夹 open local 3.找到redis.conf并打开,即可修改配置信息

讯飞星火认知大模型全新升级,全新版本、多模交互—测评结果超预期

写在前面 版本新功能 1 体验介绍 登录注册 申请体验 2 具体使用 2.1 多模态能力 2.1.1 多模理解 2.1.2 视觉问答 2.1.3 多模生成 2.2 代码能力 2.2.1 代码生成 2.2.2 代码解释 2.2.3 代码纠错 2.2.4 单元测试 2.3 插件功能 2.3.1 PPT生成 2.3.2 简历生成 2.3.4 文档问答 3 其他…

Android学习之路(3) 布局

线性布局LinearLayout 前几个小节的例程中&#xff0c;XML文件用到了LinearLayout布局&#xff0c;它的学名为线性布局。顾名思义&#xff0c;线性布局 像是用一根线把它的内部视图串起来&#xff0c;故而内部视图之间的排列顺序是固定的&#xff0c;要么从左到右排列&#xf…

Android之版本号、版本别名、API等级对应关系(全)(一百六十二)

简介&#xff1a; CSDN博客专家&#xff0c;专注Android/Linux系统&#xff0c;分享多mic语音方案、音视频、编解码等技术&#xff0c;与大家一起成长&#xff01; 优质专栏&#xff1a;Audio工程师进阶系列【原创干货持续更新中……】&#x1f680; 人生格言&#xff1a; 人生…

HTML详解连载(4)

HTML详解连载&#xff08;4&#xff09; 专栏链接 [link](http://t.csdn.cn/xF0H3)下面进行专栏介绍 开始喽CSS定义书写位置示例注意 CSS引入方式内部样式表&#xff1a;学习使用 外部演示表&#xff1a;开发使用代码示例行内样式代码示例 选择器作用基础选择器标签选择器举例特…

RISC-V公测平台发布 · 7-zip 测试

简介 7-Zip 是一个开源的压缩和解压缩工具&#xff0c;具有高压缩比和快速解压缩的特点。除了普通的文件压缩和解压缩功能之外&#xff0c;7-Zip 还提供了基准测试功能&#xff0c;通过压缩和解压缩大型文件来评估系统的处理能力和性能。 7-Zip 提供了一种在不同压缩级别和多…

BUUCTF [MRCTF2020]Ezpop解题思路

题目代码 Welcome to index.php <?php //flag is in flag.php //WTF IS THIS? //Learn From https://ctf.ieki.xyz/library/php.html#%E5%8F%8D%E5%BA%8F%E5%88%97%E5%8C%96%E9%AD%94%E6%9C%AF%E6%96%B9%E6%B3%95 //And Crack It! class Modifier {protected $var;publi…

运维监控学习笔记7

Zabbix的安装&#xff1a; 1、基础环境准备&#xff1a; 安装zabbix的yum源&#xff0c;阿里的yum源提供了zabbix3.0。 rpm -ivh http://mirrors.aliyun.com/zabbix/zabbix/3.0/rhel/7/x86_64/zabbix-release-3.0-1.el7.noarch.rpm 这个文件就是生成了一个zabbix.repo 2、安…

流程挖掘in汽车丨宝马的流程效能提升实例

汽车行业在未来10年里&#xff0c;可能会面临比过去50年更多的变化。电动化、智能化、共享化和自动驾驶等方面的趋势可能给企业流程带来以下挑战&#xff1a; 供应链管理-电动化和智能化的发展可能导致供应链中的零部件和系统结构发生变化&#xff0c;企业需要重新评估和优化供…

zookeeperAPI操作与写数据原理

要执行API操作需要在idea中创建maven项目 &#xff08;改成自己的阿里仓库&#xff09;导入特定依赖 添加日志文件 上边操作做成后就可以进行一些API的实现了 目录 导入maven依赖&#xff1a; 创建日志文件&#xff1a; 创建API客户端&#xff1a; &#xff08;1&#xff09…

Springboot 实践(5)springboot添加资源访问目录及目录测试

前文讲解了swagger测试服务控制器&#xff0c;实现了数据库数据访问&#xff0c;这些功能都是运行在后台服务器上&#xff0c;实际用户并不能直接调用接口获取数据&#xff0c;即使用户能够利用接口获取到数据&#xff0c;数据也是结构化数据&#xff0c;不能争取转化成用户使用…

基于OFDM+64QAM系统的载波同步matlab仿真,输出误码率,星座图,鉴相器,锁相环频率响应以及NCO等

目录 1.算法运行效果图预览 2.算法运行软件版本 3.部分核心程序 4.算法理论概述 2.1 OFDM原理 2.2 64QAM调制 2.3 载波同步 5.算法完整程序工程 1.算法运行效果图预览 2.算法运行软件版本 MATLAB2022a 3.部分核心程序 ............................................…