Flutter鸿蒙next 中使用 MobX 进行状态管理

引言

在 Flutter 中,状态管理是开发过程中至关重要的一部分。Flutter 提供了多种方式来管理应用的状态,如 ProviderRiverpodBLoC 等。除了这些,MobX 也是一个流行的状态管理库。MobX 是一个响应式编程库,基于观察者模式,用于处理状态变化并自动更新 UI。在这篇博客中,我们将深入探讨如何在 Flutter 中使用 MobX 来进行状态管理,包括 MobX 的基本概念、如何集成到 Flutter 项目中以及如何使用 MobX 进行状态管理的代码示例。

什么是 MobX?

MobX 是一种通过响应式编程管理应用状态的库。它依赖于观察者模式,当一个对象(例如模型、变量)发生变化时,所有依赖于该对象的部分会自动更新,从而简化了 UI 的管理。

MobX 主要有以下几个核心概念:

  • Observable: 可观察的数据对象,状态存储。
  • Action: 对状态的修改行为,保证状态更新的可追溯性。
  • Reaction: 响应式的自动更新机制,当依赖的 observable 发生变化时,自动触发 UI 更新。

如何在 Flutter 中使用 MobX

首先,确保你的项目中已经集成了 MobX 相关的依赖。

  1. 添加依赖

打开 pubspec.yaml 文件,添加以下依赖:

dependencies:flutter:sdk: fluttermobx: ^2.0.0flutter_mobx: ^2.0.0dev_dependencies:build_runner: ^2.0.0mobx_codegen: ^2.0.0
  • mobx: MobX 库本身。
  • flutter_mobx: 用于在 Flutter 中使用 MobX。
  • build_runner 和 mobx_codegen: 用于生成 MobX 相关的代码。
  1. 创建 MobX Store

在 MobX 中,状态管理通常是通过 Store 来实现的。我们需要创建一个包含 Observable 状态和 Action 方法的类。

import 'package:mobx/mobx.dart';part 'counter_store.g.dart'; // 自动生成代码的位置class CounterStore = _CounterStore with _$CounterStore;abstract class _CounterStore with Store {@observableint count = 0; // 被观察的状态变量@actionvoid increment() {count++;}@actionvoid decrement() {count--;}
}

在上面的代码中:

  • @observable 用来标记需要被观察的状态(即 count 变量)。当 count 的值发生变化时,UI 会自动更新。
  • @action 用来标记修改状态的方法(即 increment 和 decrement 方法)。这是 MobX 规定的规则,用于确保所有的状态更新都通过动作函数进行,这样能避免直接修改状态。
  1. 生成 MobX 代码

在终端中运行以下命令,生成 MobX 的辅助代码:

 

bash

flutter pub run build_runner build

这将自动生成一个名为 counter_store.g.dart 的文件,里面包含了 MobX 需要的辅助方法(如 observableaction 的实现)。

  1. 使用 MobX Store

在 Flutter 中,使用 MobX store 可以通过 Observer 小部件来实现。当 Observable 数据发生变化时,Observer 会自动重建 UI 以反映最新的状态。

import 'package:flutter/material.dart';
import 'package:flutter_mobx/flutter_mobx.dart';
import 'counter_store.dart';void main() {runApp(MyApp());
}class MyApp extends StatelessWidget {final CounterStore counterStore = CounterStore();@overrideWidget build(BuildContext context) {return MaterialApp(home: Scaffold(appBar: AppBar(title: Text("MobX Example")),body: Center(child: Column(mainAxisAlignment: MainAxisAlignment.center,children: [Observer(builder: (_) {return Text('Count: ${counterStore.count}',style: TextStyle(fontSize: 30),);},),SizedBox(height: 20),ElevatedButton(onPressed: counterStore.increment,child: Text("Increment"),),ElevatedButton(onPressed: counterStore.decrement,child: Text("Decrement"),),],),),),);}
}

在这个示例中,我们创建了一个 CounterStore 实例,并通过 Observer 小部件来观察 count 的变化。当 count 发生变化时,Observer 会自动重新构建相关的 UI 元素,显示新的 count 值。

代码详细解释

1. MobX Store 的实现

CounterStore 类中,我们定义了一个 count 变量,并标记为 @observable,这表示该变量是可以被 MobX 观察的。当 count 变化时,所有依赖该值的 UI 部件会自动更新。接着,我们定义了两个 @action 方法:incrementdecrement,它们分别用于增加和减少 count 的值。MobX 强制要求我们通过 @action 方法来修改 observable 的值,这样可以确保所有的状态更新都是有条理的,并且便于调试和测试。

2. 生成代码

运行 flutter pub run build_runner build 命令后,Flutter 会生成一个自动的代码文件(例如:counter_store.g.dart)。这个文件包含了 MobX 的内部实现逻辑,比如 observable 状态的 getter 和 setter,以及 @action 的相关实现。这部分代码是自动生成的,我们不需要手动编写,MobX 会在后台处理这些繁琐的任务。

3. UI 与 MobX Store 的绑定

在 Flutter 中,MobX 使用 Observer 小部件来观察状态的变化。通过在 Observer 小部件的 builder 回调中,我们可以访问 CounterStorecount 值。每当 count 改变时,Observer 会自动更新 UI。

ElevatedButton 小部件的 onPressed 回调中,我们调用了 counterStore.incrementcounterStore.decrement 方法来更新状态。这些更新操作会触发 UI 的自动更新。

4. 反应式编程

MobX 使得反应式编程变得更加容易。当你修改 observable 变量时,依赖该变量的所有部分(如 UI)都会自动更新。你无需手动处理状态变化或 UI 刷新,MobX 会为你处理好这一切。这种自动的依赖追踪和更新机制是 MobX 的强大之处。

结语

使用 MobX 进行状态管理为 Flutter 应用带来了简洁且高效的解决方案。通过 @observable@action 结合 Observer,我们能够轻松地实现响应式的 UI 更新。虽然 MobX 可能在某些场景下有些过于抽象,但它为大型应用提供了一种非常高效、灵活的状态管理方式。如果你的应用需要进行复杂的状态管理,并且希望避免过多的手动控制 UI 刷新,那么 MobX 是一个不错的选择。

希望这篇博客能帮助你理解 MobX 在 Flutter 中的使用方式,并成功将其应用到你的项目中!

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

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

相关文章

第十九周机器学习笔记:GAN的数学理论知识与实际应用的操作

第十九周周报 摘要Abstratc一、机器学习——GAN Basic Theory1. Maximum Likelihood Estimation2. 复习训练GAN的过程3. Objective function与JS散度相关性推导4. GAN的实际做法 总结 摘要 本周周报主要围绕生成对抗网络(GAN)的基础知识和理论进行深入探…

刷题小记11:栈队列

包括单调栈和优先队列 232. 用栈实现队列 用栈实现队列 两个栈 入队:向入队栈中加入元素 出队:从出队栈中出栈元素,如果出队栈为空,将入队栈所有元素入栈到出队栈。这样顺序就对了 225. 用队列实现栈 用队列实现栈 优化 …

【Qt问题】解决 Cannot retrieve debugging output

【Qt问题】解决 Cannot retrieve debugging output Chapter1 【Qt问题】解决 Cannot retrieve debugging output方案1 关闭其他Qt工程实例(等于没说)方案2 在PRO文件中,加上CONFIG console Chapter1 【Qt问题】解决 Cannot retrieve debuggi…

git 提交代码流程

1. 公-->私-->本-->私-->公 缺点:多了一个步骤,就多了一次申请时间,首先在公仓申请合并到私仓,私仓同意合并,获取到公仓最新版本; 优点:不容易污染公仓 2. 公-->本-->私--&…

Java 中的 transient 关键字:深入解析与实战

在 Java 编程中,transient 关键字是一个非常有用的工具,尤其是在处理对象序列化时。尽管 transient 关键字在日常开发中可能不常被使用,但了解它的作用和使用场景对于提升代码的安全性和性能至关重要。本文将深入探讨 transient 关键字的作用…

App渠道来源追踪方案全面分析(iOS/Android/鸿蒙)

一、App 渠道来源追踪概述 渠道来源统计/追踪,其原理都可以称之为归因,归因是用于判断用户在什么原因、什么时间、什么场景下载了 App,以及打通他们在激活 App 后进行的一系列操作(比如注册、付费、加购等)。 渠道来…

参数跟丢了之JS生成器和包装器

如需转载请注明出处.欢迎小伙伴一起讨论技术. 逆向网址:aHR0cHM6Ly91bmlvbi5qZC5jb20vcHJvTWFuYWdlci9pbmRleD9wYWdlTm89MQ 跟踪接口:aHR0cHM6Ly9hcGkubS5qZC5jb20vYXBp 跟踪参数:h5st 本文目标:记录学习下自定义的生成器和包装器,不做具体的参数加密逻辑分析 直接启动器进…

Redis集群——针对实习面试

目录 Redis集群Redis集群解决了什么问题?Redis集群是如何分片的?什么是Sentinel?Redis如何使用哨兵(Sentinel)系统?集群如何进行故障转移?Redis集群中的主从复制模型是怎样的?Redis集…

【种完麦子,我就往南走,去西双版纳,过个冬天!】

麦子奶奶:冰哥,你好。 大冰:你好,咱俩不定谁大呢。 麦子奶奶:嗯,我大,我60多了,你各方面都是哥。 大冰:阿姨好 麦子奶奶:我想出去看看祖国的大好河山&…

长亭那个检测能力超强的 WAF,出免费版啦

告诉你们一个震撼人心的消息,那个检测能力超强的 WAF——长亭雷池,他推出免费社区版啦,体验地址见文末。 八年前我刚从学校毕业,在腾讯做安全研究,看到宇森在 BlackHat 上演讲的议题 《永别了,SQL 注入》 …

Elasticsearch+kibana+filebeat的安装及使用

版本7.6.0 自己去官网下载或者私信找我要,jdk是8版本 1.ES安装 网上有好多安装教程可以自己去搜索 这个是我的es文件路径: { “name” : “node-1”, “cluster_name” : “elasticsearch”, “cluster_uuid” : “NIepktULRfepkje3JHw8NA”, “ve…

NVR小程序接入平台/设备EasyNVR多品牌NVR管理工具/设备汇聚公共资源场景方案全析

随着信息技术的飞速发展,视频监控已经成为现代社会安全管理和业务运营不可或缺的一部分。特别是在公共资源管理方面,视频监控的应用日益广泛,涵盖了智慧城市、智能交通、大型企业以及校园安防等多个领域。NVR小程序接入平台EasyNVR作为一款功…

ThingsBoard规则链节点:RPC Call Reply节点详解

引言 1. RPC Call Reply 节点简介 2. 节点配置 2.1 基本配置示例 3. 使用场景 3.1 设备控制 3.2 状态查询 3.3 命令执行 4. 实际项目中的应用 4.1 项目背景 4.2 项目需求 4.3 实现步骤 5. 总结 引言 ThingsBoard 是一个开源的物联网平台,提供了设备管理…

【论文复现】基于图卷积网络的轻量化推荐模型

本文所涉及所有资源均在这里可获取。 📕作者简介:热爱跑步的恒川,致力于C/C、Java、Python等多编程语言,热爱跑步,喜爱音乐、摄影的一位博主。 📗本文收录于论文复现系列,大家有兴趣的可以看一看…

sql数据库-DQL-基本查询

目录 举例表emp 查询多个字段 查询整张表所有数据 给字段名起别名(更方便阅读) 去除重复的数据 举例表emp 查询多个字段 SELECT 字段1,字段2,字段3...FROM 表名; 举例查询emp表中的name,workno,age字段返回 查询整张表所有数据 …

OpenCV通过指针裁剪图像

OpenCV 中mat 格式的像素数值都是连续排列的。为了深入了解cuda 编程。我们来写一个简单的小程序测试一下。 1 不裁剪 cv::Mat crop_image(int(height), int(width), CV_8UC3, image.data);2 只保留图像1/3 cv::Mat crop_image(int(height/3), int(width), CV_8UC3, image.da…

Perforce《2024游戏技术现状报告》Part2:游戏引擎、版本控制、IDE及项目管理等多种开发工具的应用分析

游戏开发者一直处于创新前沿。他们的实践、工具和技术受到各行各业的广泛关注,正在改变着组织进行数字创作的方式。 近期,Perforce发布了《2024游戏技术现状报告》,通过收集来自游戏、媒体与娱乐、汽车和制造业等高增长行业的从业者、管理人…

软件测试面试题及答案

以下是软件测试相关的面试题及答案! 1、测试分为哪几个阶段? 一般来说分为5个阶段:单元测试、集成测试、确认测试、系统测试、验收测试 2、软件测试的流程是什么? 需求调查:全面了解系统概况、应用领域、软件开发周期、软件开发环境、开发组织、时…

Python实例:爱心代码

前言 在编程的奇妙世界里,代码不仅仅是冰冷的指令集合,它还可以成为表达情感、传递温暖的独特方式。今天,我们将一同探索用 Python 语言绘制爱心的神奇之旅。 爱心,这个象征着爱与温暖的符号,一直以来都在人类的情感世界中占据着特殊的地位。而通过 Python 的强大功能,…

TypeError: can‘t multiply sequence by non-int of type ‘float‘

通过python程序编写excel表格中的数据,在计算数值时出现数值类型错误: TypeError: cant multiply sequence by non-int of type float 问题分析: 读取的Excel文件中的单元格数据,读取的数值有可能不是数值类型,而是含…