Flutter 鸿蒙next 中使用 MobX 进行状态管理
Flutter & 鸿蒙next 中使用 MobX 进行状态管理
在应用开发中,状态管理是一个至关重要的环节,特别是在复杂的Flutter或鸿蒙next项目中。状态的变化往往会影响UI的更新,因此,选择一种高效、灵活的状态管理工具显得尤为重要。MobX 作为一种响应式状态管理库,以其简洁的API和强大的功能,成为了Flutter和鸿蒙next开发中备受欢迎的选择。本文将详细介绍如何在Flutter和鸿蒙next中使用MobX进行状态管理。
一、MobX 简介
MobX 是一个强大的状态管理库,它采用响应式编程的思想,通过追踪依赖关系,在状态发生变化时自动更新UI。MobX 的核心理念是“反应式状态管理”,即状态的变化会自动触发依赖该状态的组件重新渲染。这使得开发者可以专注于状态的管理,而不需要手动控制UI的更新。
MobX 提供了几个核心概念:
- Observable(可观察对象):任何可以被MobX追踪其变化的JavaScript对象或值。
- Action(动作):修改状态的方法,通常用于响应用户事件或副作用。
- Reaction(反应):当状态发生变化时,自动执行的一段代码,如重新渲染UI。
- Computed(计算属性):基于其他状态派生出的新状态,当依赖的状态变化时,计算属性会自动重新计算。
二、在Flutter中使用MobX
Flutter是一个用于构建跨平台移动应用程序的UI工具包,它允许开发者使用Dart语言编写代码。在Flutter中,MobX状态管理库通过flutter_mobx和mobx两个包来实现。
1. 添加依赖
首先,需要在pubspec.yaml文件中添加flutter_mobx和mobx的依赖:
dependencies:flutter:sdk: fluttermobx: ^0.3.9+3flutter_mobx: ^0.3.3+3dev_dependencies:build_runner: ^1.7.1mobx_codegen: ^0.3.10+1
然后,运行flutter pub get命令来下载这些依赖。
2. 创建可观察对象
接下来,需要创建一个可观察对象。这通常是一个包含状态的类,并使用@observable装饰器来标记其状态属性。同时,使用@action装饰器来标记修改状态的方法。
例如,创建一个简单的计数器模型:
import 'package:mobx/mobx.dart';
part 'counter.g.dart';class Counter = CounterMobx with _$Counter;abstract class CounterMobx with Store {int value = 0;void increment() {value++;}void decrement() {value--;}void set(int value) {this.value = value;}
}
注意,这里使用了part 'counter.g.dart';语法,这是MobX代码生成的一部分。接下来,需要运行代码生成命令来生成counter.g.dart文件:
flutter packages pub run build_runner build
3. 在页面中使用MobX
现在,可以在Flutter页面中使用这个计数器模型了。使用Observer组件来观察状态的变化,并自动更新UI。
import 'package:flutter/material.dart';
import 'package:flutter_mobx/flutter_mobx.dart';
import 'package:mobx/mobx.dart';
import 'counter.dart';class CounterPage extends StatelessWidget {Widget build(BuildContext context) {final Counter counter = Counter();return MaterialApp(title: 'Mobx Counter',theme: ThemeData(primaryColor: Colors.blue),home: Scaffold(appBar: AppBar(title: Text('Mobx Counter'),),body: Center(child: Column(mainAxisAlignment: MainAxisAlignment.center,children: <Widget>[Text('You have pushed the button this many times:'),Observer(builder: (_) => Text('${counter.value}',style: Theme.of(context).textTheme.display1,),),],),),floatingActionButton: Column(crossAxisAlignment: CrossAxisAlignment.end,mainAxisAlignment: MainAxisAlignment.end,children: <Widget>[Padding(padding: EdgeInsets.symmetric(vertical: 5.0),child: FloatingActionButton(onPressed: counter.increment,tooltip: 'Increment',child: Icon(Icons.add),),),Padding(padding: EdgeInsets.symmetric(vertical: 5.0),child: FloatingActionButton(onPressed: counter.decrement,tooltip: 'Decrement',child: Icon(Icons.remove),),),],),),);}
}
在这个例子中,Observer组件包裹了显示计数器值的Text组件。当counter.value发生变化时,Observer会自动触发UI的重新渲染。
三、在鸿蒙next中使用MobX(概念性探讨)
虽然鸿蒙next(HarmonyOS)和Flutter在技术上有所不同,但状态管理的核心思想是一致的。在鸿蒙next中,虽然没有直接的MobX库,但可以通过类似的概念和工具来实现响应式状态管理。
鸿蒙next提供了自己的状态管理机制,如状态装饰器(@State、@Provide、@Consume等)。这些装饰器允许开发者在组件内部和组件之间共享和管理状态。然而,与MobX相比,鸿蒙next的原生状态管理机制可能不够灵活和强大。因此,在鸿蒙next项目中,开发者可能会考虑使用类似MobX的第三方库,或者借鉴MobX的响应式编程思想来构建自己的状态管理解决方案。
1. 状态装饰器
鸿蒙next中的状态装饰器提供了一种简单的方式来管理组件内的状态。例如,@State装饰器用于标记组件内的状态变量,当这些变量发生变化时,组件会重新渲染。
@State stateCount: number = 0;increment() {this.stateCount++;
}
在这个例子中,stateCount是一个被@State装饰的状态变量。当increment方法被调用时,stateCount的值会增加,并且使用这个状态的UI部分会自动重新渲染。
2. 全局状态管理
在鸿蒙next中,可以通过@ProvideGlobal和@ConsumeGlobal装饰器来实现全局状态的管理。这些装饰器允许开发者在应用的全局范围内提供一个状态,并允许任何组件访问和消费这个状态。
@ProvideGlobal appTheme: string = "light";updateTheme() {this.appTheme = "dark";
}
在其他组件中,可以使用@ConsumeGlobal装饰器来访问这个全局状态。
@ConsumeGlobal appTheme: string;
虽然这些装饰器提供了一种简单的方式来管理全局状态,但它们可能不够灵活,无法满足复杂应用的需求。在这种情况下,开发者可能会考虑使用类似MobX的第三方库,或者构建自己的响应式状态管理解决方案。
3. 响应式编程思想
无论使用哪种状态管理工具或库,响应式编程的思想都是相通的。在鸿蒙next中,开发者可以借鉴MobX的响应式编程思想来构建自己的状态管理解决方案。这包括:
- 状态集中管理:将状态集中在一个地方进行管理,而不是分散在多个组件中。
- 依赖追踪:追踪状态的变化和依赖关系,以便在状态发生变化时自动更新UI。
- 计算属性:基于其他状态派生出新的状态,当依赖的状态变化时,计算属性会自动重新计算。
通过借鉴这些思想,开发者可以在鸿蒙next中构建出高效、灵活的状态管理解决方案。
四、总结
MobX作为一种强大的响应式状态管理库,在Flutter和鸿蒙next中都得到了广泛的应用。在Flutter中,通过flutter_mobx和mobx包,开发者可以轻松实现状态的管理和UI的自动更新。而在鸿蒙next中,虽然没有直接的MobX库,但开发者可以借鉴MobX的响应式编程思想来构建自己的状态管理解决方案。无论使用哪种工具或库,理解状态管理的核心思想都是至关重要的。通过合理管理状态,开发者可以构建出高效、灵活、易于维护的移动应用程序。
相关文章:
Flutter 鸿蒙next 中使用 MobX 进行状态管理
Flutter & 鸿蒙next 中使用 MobX 进行状态管理 在应用开发中,状态管理是一个至关重要的环节,特别是在复杂的Flutter或鸿蒙next项目中。状态的变化往往会影响UI的更新,因此,选择一种高效、灵活的状态管理工具显得尤为重要。Mo…...
1.62亿元!812个项目立项!上海市2024年度“科技创新行动计划”自然科学基金项目立项
本期精选SCI&EI ●IEEE 1区TOP 计算机类(含CCF); ●EI快刊:最快1周录用! 知网(CNKI)、谷歌学术期刊 ●7天录用-检索(100%录用),1周上线; 免费稿件评估 免费匹配期…...
Redis数据库测试和缓存穿透、雪崩、击穿
Redis数据库测试实验 实验要求 1.新建一张user表,在表内插入10000条数据。 2.①通过jdbc查询这10000条数据,记录查询时间。 ②通过redis查询这10000条数据,记录查询时间。 3.①再次查询这一万条数据,要求根据年龄进行排序&#…...
[vulnhub] DarkHole: 2
https://www.vulnhub.com/entry/darkhole-2,740/ 端口扫描主机发现 探测存活主机,185是靶机 # nmap -sP 192.168.75.0/24 Starting Nmap 7.94SVN ( https://nmap.org ) at 2024-11-08 18:02 CST Nmap scan report for 192.168.75.1 Host is up (0.…...
《XGBoost算法的原理推导》12-2 t轮迭代中对样本i的预测值 公式解析
本文是将文章《XGBoost算法的原理推导》中的公式单独拿出来做一个详细的解析,便于初学者更好的理解。 好的,公式(12-2)表示的是 XGBoost 在第 t t t 轮迭代中对样本 i i i 的预测值。它说明了在第 t t t 轮迭代中,模型的预测是通过累加之前…...
./bin/mindieservice_daemon启动成功
接MindIE大模型测试及报错Fatal Python error: PyThreadState_Get: the function must be called with the GIL held,-CSDN博客经过调整如下红色部分参数,昇腾310P3跑起来了7b模型: rootdev-8242526b-01f2-4a54-b89d-f6d9c57c692d-qjhpf:/home/apulis-de…...
Linux: network: ip link M-DOWN的具体含义是什么?
文章目录 参考简介实例代码解释openstack上的显示如果是在一个interface上建立了vlan参考 https://unix.stackexchange.com/questions/348327/using-ip-what-does-m-down-mean www.policyrouting.org/iproute2.doc.html#ss9.1 简介 是指上一级的接口的状态。 实例 4: ersp…...
Spring中的过滤器和拦截器
Spring中的过滤器和拦截器 一、引言 在Spring框架中,过滤器(Filter)和拦截器(Interceptor)是实现请求处理的两种重要机制。它们都基于AOP(面向切面编程)思想,用于在请求的生命周期…...
leetcode20.括号匹配
题目描述 给定一个只包括 ‘(’,‘)’,‘{’,‘}’,‘[’,‘]’ 的字符串 s ,判断字符串是否有效。 有效字符串需满足: 左括号必须用相同类型的右括号闭合。 左括号必须以正确的顺序闭合。 每个…...
Unity性能优化-具体操作
批量渲染是通过减少CPU向GPU发送渲染命令(DrawCall)的次数,以及减少GPU切换渲染状态的次数,尽量让GPU一次多做一些事情,来提升逻辑线和渲染线的整体效率。 Draw Call性能消耗原因是命令从Runtime到Driver的过程中&…...
【嵌入式开发——ARM】1ARM架构
嵌入式领域,使用ARM架构的芯片公司可不占少数吧,intel的x86架构主要占据PC、服务器市场,ARM架构主要占据移动市场。x86架构和ARM架构不同的主要原因,是背后使用的计算机指令集不同。计算机有自己的语言系统(汇编&#…...
Linux中.NET读取excel组件,不会出现The type initializer for ‘Gdip‘ threw an exception异常
组件,可通过nuget安装,直接搜名字: ExcelDataReader using ConsoleAppReadFileData.Model; using ExcelDataReader; using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Threading.Task…...
mmclassification的配置文件样本
# 需要修改的参数 img_size 480 class_name [fuqi,ok] num_classes len(class_name) data_root /home/apulis-test/teamdata/yz_dataset/fuqi max_epochs300 val_interval1 train_batch_size 16 val_batch_size 1 load_from "swin_tiny_224_b16x64_300e_imagenet_…...
Java基础——类和对象的定义链表的创建,输出
目录 什么是类? 什么是对象? 如何创建链表? 尾插法: 头插法: 输出链表的长度 输出链表的值 什么是类? 创建Java程序必须创建一个类class. .java程序需要经过javac指令将文件翻译为.class字节码文件,…...
Linux应用项目之量产工具(一)——显示系统
目录 前言 项目特点及介绍 ① 简单易用 ② 软件可配置、易扩展 ③ 纯 C 语言编程 软件总框架 显示系统 1.数据结构抽象 disp_manager.h 2.Framebuffer编程 framebuffer.c 3.显示管理 disp_manager.c 4.单元测试 disp_test.c 顶层目录Makefile 顶层目录Makefil…...
Python小白学习教程从入门到入坑------第二十九课 访问模式(语法进阶)
目录 一、访问模式 1.1 r 1.2 w 1.3 1.3.1 r 1.3.2 w 1.3.3 a 1.4 a 一、访问模式 模式可做操作若文件不存在是否覆盖r只能读报错-r可读可写报错是w只能写创建是w可读可写创建是a只能写创建否,追加写a可读可写创建否,追加写 1.1 r r&…...
使用 PageHelper 在 Spring Boot 项目中实现分页查询
目录 前言1. 项目环境配置1.1 添加 PageHelper 依赖1.2 数据库和 MyBatis 配置 2. 统一的分页响应类3. 使用 PageHelper 实现分页查询3.1 Service 层分页查询实现3.2 PageHelper 分页注意事项 4. 控制层调用示例5. 常见问题与解决方案5.1 java.util.ArrayList cannot be cast t…...
深度学习-张量相关
一. 张量的创建 张量简介 张量是pytorch的基本数据结构 张量,英文为Tensor,是机器学习的基本构建模块,是以数字方式表示数据的形式。 例如,图像可以表示为形状为 [3, 224, 224] 的张量,这意味着 [colour_channels, h…...
电脑提示xinput1_3.dll丢失怎么解决,分享6种有效的解决方法
xinput1_3.dll 是一个动态链接库(DLL)文件,它在Windows操作系统中扮演着重要的角色,特别是在处理游戏控制器和其他输入设备的交互方面。这个文件是Microsoft DirectX软件包的一部分,DirectX是微软公司开发的一个多媒体…...
【计网】数据链路层笔记
【计网】数据链路层 数据链路层概述 数据链路层在网络体系结构中所处的地位 链路、数据链路和帧 链路(Link)是指从一个节点到相邻节点的一段物理线路(有线或无线),而中间没有任何其他的交换节点。 数据链路(Data Link)是基于链路的。当在一条链路上传送数据时&a…...
基于服务器使用 apt 安装、配置 Nginx
🧾 一、查看可安装的 Nginx 版本 首先,你可以运行以下命令查看可用版本: apt-cache madison nginx-core输出示例: nginx-core | 1.18.0-6ubuntu14.6 | http://archive.ubuntu.com/ubuntu focal-updates/main amd64 Packages ng…...
【ROS】Nav2源码之nav2_behavior_tree-行为树节点列表
1、行为树节点分类 在 Nav2(Navigation2)的行为树框架中,行为树节点插件按照功能分为 Action(动作节点)、Condition(条件节点)、Control(控制节点) 和 Decorator(装饰节点) 四类。 1.1 动作节点 Action 执行具体的机器人操作或任务,直接与硬件、传感器或外部系统…...
ffmpeg(四):滤镜命令
FFmpeg 的滤镜命令是用于音视频处理中的强大工具,可以完成剪裁、缩放、加水印、调色、合成、旋转、模糊、叠加字幕等复杂的操作。其核心语法格式一般如下: ffmpeg -i input.mp4 -vf "滤镜参数" output.mp4或者带音频滤镜: ffmpeg…...
Python爬虫(二):爬虫完整流程
爬虫完整流程详解(7大核心步骤实战技巧) 一、爬虫完整工作流程 以下是爬虫开发的完整流程,我将结合具体技术点和实战经验展开说明: 1. 目标分析与前期准备 网站技术分析: 使用浏览器开发者工具(F12&…...
mysql已经安装,但是通过rpm -q 没有找mysql相关的已安装包
文章目录 现象:mysql已经安装,但是通过rpm -q 没有找mysql相关的已安装包遇到 rpm 命令找不到已经安装的 MySQL 包时,可能是因为以下几个原因:1.MySQL 不是通过 RPM 包安装的2.RPM 数据库损坏3.使用了不同的包名或路径4.使用其他包…...
【Oracle】分区表
个人主页:Guiat 归属专栏:Oracle 文章目录 1. 分区表基础概述1.1 分区表的概念与优势1.2 分区类型概览1.3 分区表的工作原理 2. 范围分区 (RANGE Partitioning)2.1 基础范围分区2.1.1 按日期范围分区2.1.2 按数值范围分区 2.2 间隔分区 (INTERVAL Partit…...
初学 pytest 记录
安装 pip install pytest用例可以是函数也可以是类中的方法 def test_func():print()class TestAdd: # def __init__(self): 在 pytest 中不可以使用__init__方法 # self.cc 12345 pytest.mark.api def test_str(self):res add(1, 2)assert res 12def test_int(self):r…...
回溯算法学习
一、电话号码的字母组合 import java.util.ArrayList; import java.util.List;import javax.management.loading.PrivateClassLoader;public class letterCombinations {private static final String[] KEYPAD {"", //0"", //1"abc", //2"…...
排序算法总结(C++)
目录 一、稳定性二、排序算法选择、冒泡、插入排序归并排序随机快速排序堆排序基数排序计数排序 三、总结 一、稳定性 排序算法的稳定性是指:同样大小的样本 **(同样大小的数据)**在排序之后不会改变原始的相对次序。 稳定性对基础类型对象…...
招商蛇口 | 执笔CID,启幕低密生活新境
作为中国城市生长的力量,招商蛇口以“美好生活承载者”为使命,深耕全球111座城市,以央企担当匠造时代理想人居。从深圳湾的开拓基因到西安高新CID的战略落子,招商蛇口始终与城市发展同频共振,以建筑诠释对土地与生活的…...
