阳江专业手机网站制作公司/网课免费平台
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…...

蓝牙FTP 协议详解及 Android 实现
文章目录 前言一、什么是蓝牙 FTP 协议?二、FTP 的工作流程1.蓝牙设备初始化2. 设备发现与配对3. 建立OBEX FTP 连接4. 文件传输文件上传(通过OBEX PUT命令)文件下载(通过OBEX GET命令) 5. 关闭OBEX会话 三、进阶应用与…...

【前端】Svelte:动画效果
在现代前端开发中,动画效果可以大大提升用户体验,使应用更生动、易用。Svelte 提供了灵活的动画 API,让开发者能够快速实现从简单过渡到复杂动画的各种效果。本文将系统性地介绍 Svelte 的动画功能,并通过多个示例演示如何创建动感…...

2024系统架构师--论基于架构的软件设计方法(ABSD)及应用(论文范文)
题目: 基于架构的软件设计(Architecture-Based Software Design,ABSD)方法以构成软件架构的商业、质量和功能需求等要素来驱动整个软件开发过程。ABSD是一个自顶向下,递归细化的软件开发方法,它以软件系统功能的分解为基础,通过选择架构风格实现质量和商业需求,并强调在架…...

ORU 的 Open RAN 管理平面 (M 平面)
[TOC](ORU 的 Open RAN 管理平面 (M 平面)) ORU 的 Open RAN 管理平面 (M 平面) https://www.techplayon.com/open-ran-management-plane-m-plane-for-open-radio-unit/ ORU M 平面 在 ORAN 中,设置参数的 O-RU 管理功能是通过 M-Plane 完成的。管理功能包括 O-…...

软件缺陷等级评定综述
1. 前言 正确评估软件缺陷等级,在项目的生命周期中有着重要的作用: 指导缺陷修复的优先级和资源分配 在软件开发和维护过程中,资源(包括人力、时间和资金)是有限的。通过明确缺陷的危险等级,可以帮助团队合…...

Nuxt.js 应用中的 schema:extend事件钩子详解
title: Nuxt.js 应用中的 schema:extend事件钩子详解 date: 2024/11/10 updated: 2024/11/10 author: cmdragon excerpt: schema:extend 钩子使开发者能够扩展默认数据模式,为特定业务需求添加自定义字段和验证。 categories: 前端开发tags: Nuxt钩子数据扩展自定义验证应…...

自然语言处理在客户服务中的应用
💓 博客主页:瑕疵的CSDN主页 📝 Gitee主页:瑕疵的gitee主页 ⏩ 文章专栏:《热点资讯》 自然语言处理在客户服务中的应用 自然语言处理在客户服务中的应用 自然语言处理在客户服务中的应用 引言 自然语言处理概述 定义…...

OpenCoder:首个完全开源的顶级代码大模型,训练秘籍全公开!| LLM×MapReduce,无需训练就超越GPT-4!
大模型领域的发展日新月异,每天都有许多有趣的论文值得深入品读。下面是本期觉得比较有意思的论文: 1、OpenCoder:首个完全开源的顶级代码大模型,训练秘籍全公开!2、超长文本处理新突破!LLMMapReduce&…...

springboot静态资源映射不生效问题
最近有个同事问我,静态资源映射不生效的问题,很正常我想不就是配置下资源路径就可以了吗?类似配置如下代码 Configuration public class CorsConfig implements WebMvcConfigurer {Overridepublic void addResourceHandlers(ResourceHandlerR…...

通过 SSH 隧道将本地端口转发到远程主机
由于服务器防火墙,只开放了22端口,想要通过5901访问服务器上的远程桌面,可以通过下面的方式进行隧道转发。 一、示例命令 这条代码的作用是通过 SSH 创建一个 本地端口转发,将你本地的端口(5901)通过加密的 SSH 隧道连接到远程服务器上的端口(5901)。这种方式通常用于在…...