flutter鸿蒙版本mvvm架构思想原理

news/2024/12/23 7:01:03/

目录

写在前面

1. 整体架构概述

2. 各文件详细讲解

2.1. main.dart

2.2. CounterViewModel.dart

2.3. MyHomePage.dart

2.4. Model.dart

3. MVVM架构思想分析

3.1. 分离关注点

3.2. 数据绑定

3.3. 可维护性和可测试性

写在最后


写在前面

在Flutter中实现MVVM(Model-View-ViewModel)架构是为了将UI(视图)与业务逻辑(模型和视图模型)分离,提高代码的可维护性和可读性。

1. 整体架构概述

  • Model: 数据层,处理应用程序的业务逻辑和数据管理。
  • View: 用户界面层,负责展示数据并接受用户输入。
  • ViewModel: 连接模型和视图的中间层,处理与视图相关的业务逻辑,并通知视图更新。

2. 各文件详细讲解

2.1. main.dart
import 'package:flutter/material.dart';
import 'package:mvvm/View/MyHomePage.dart';
import 'package:provider/provider.dart';
import 'Model/Model.dart';
import 'ViewModel/CounterViewModel.dart';
void main() {runApp(const MyApp());
}
class MyApp extends StatelessWidget {const MyApp({super.key});@overrideWidget build(BuildContext context) {return MaterialApp(title: 'Flutter MVVM Example',home: ChangeNotifierProvider(create: (context) => CounterViewModel(CounterModel()),child: MyHomePage(),),);}
}
  • 导入依赖: 导入Flutter的Material库、MVVM架构的视图、提供者库、模型和视图模型。
  • main函数: 应用程序的入口,使用runApp启动MyApp
  • MyApp:
    • MaterialApp用于创建一个Material风格的应用。
    • 使用ChangeNotifierProvider来创建CounterViewModel实例并将其提供给MyHomePage。这样,MyHomePage及其子组件就能访问CounterViewModel
2.2. CounterViewModel.dart
import 'package:flutter/foundation.dart';
import '../Model/Model.dart';class CounterViewModel extends ChangeNotifier {final CounterModel _counterModel;CounterViewModel(this._counterModel);int get counter => _counterModel.counter;void incrementCounter() {_counterModel.increment();notifyListeners();}
}
  • 导入依赖: 导入flutter/foundation.dart和模型。
  • CounterViewModel:
    • 继承自ChangeNotifier,实现了观察者模式,使得UI组件能够监听到数据的变化。
    • _counterModelCounterModel的实例,负责持有计数数据。
    • counter: 一个getter,提供当前计数值。
    • incrementCounter: 增加计数值的方法,并调用notifyListeners()来通知UI进行更新。
2.3. MyHomePage.dart
import 'package:flutter/cupertino.dart';
import 'package:flutter/material.dart';
import 'package:provider/provider.dart';
import '../ViewModel/CounterViewModel.dart';
class MyHomePage extends StatefulWidget {MyHomePage({super.key});@overrideState<MyHomePage> createState() => MyHomePage_State();
}
class MyHomePage_State extends State<MyHomePage> {@overrideWidget build(BuildContext context) {final counterViewModel = Provider.of<CounterViewModel>(context);return Scaffold(appBar: AppBar(title: Text('Flutter MVVM Example'),),body: Center(child: Column(mainAxisAlignment: MainAxisAlignment.center,children: <Widget>[Text('flutter鸿蒙版本MvvM原理的说明:Dart'),Text('页面MyHomePage向中间层CounterViewModel要数据'),//业务层(负责直接面对用户的一层)Text('中间层CounterViewModel向数据处理层Model要数据:中间创建一个方法并使用该方法调用数据处理层的方法'),Text('中间层方法调用完数据处理层方法后使用notifyListeners来通知页面更新UI'),Text('${counterViewModel.counter}',style: Theme.of(context).textTheme.headlineMedium,),],),),floatingActionButton: FloatingActionButton(onPressed: counterViewModel.incrementCounter,tooltip: 'Increment',child: Icon(Icons.add),),);}
}
  • 导入依赖: 导入Flutter库和Provider。
  • MyHomePage:
    • 作为应用的主要视图,展示了计数器的当前值。
    • build方法:
      • 使用Provider.of<CounterViewModel>(context)获取CounterViewModel的实例。
      • 创建一个Scaffold,显示应用的结构。
      • 显示一些文本以说明MVVM的工作原理,并动态展示计数值。
      • 使用FloatingActionButton调用incrementCounter方法以增加计数值。
2.4. Model.dart
class CounterModel {int _counter = 0;int get counter => _counter;void increment() {_counter++;}
}
  • CounterModel:
    • 作为数据模型,负责持有和管理计数数据。
    • _counter是一个私有变量,用于存储计数值。
    • counter: 一个getter,提供对计数值的访问。
    • increment: 方法用于增加计数值。

3. MVVM架构思想分析

3.1. 分离关注点
  • Model(模型):

    • 负责数据的管理和业务逻辑,独立于UI层。所有数据操作都在这里完成,如获取、更新等。
  • View(视图):

    • 负责展示数据并处理用户输入。UI组件只关心如何展示数据,而不涉及数据如何被处理。
  • ViewModel(视图模型):

    • 作为中介,负责协调模型和视图之间的交互。
    • 处理从视图接收的用户输入,并调用模型进行相应的数据处理。
    • 一旦模型的数据发生变化,ViewModel会通过notifyListeners()通知视图更新UI。
3.2. 数据绑定
  • 在这个示例中,Flutter的Provider包使得数据绑定变得简单。通过ChangeNotifierProvider,视图可以非常方便地监听数据变化。
  • 当用户点击浮动按钮增加计数时,视图模型调用模型的方法来更新数据,并通知视图重新构建。这种响应式的设计使得开发变得更加高效。
3.3. 可维护性和可测试性
  • MVVM架构使得代码结构更加清晰,增强了可维护性。
  • 各个层次的分离使得测试变得更加简单,例如可以单独测试模型和视图模型而无需依赖UI。

写在最后

在Flutter中实现MVVM架构的关键在于利用Provider进行状态管理,将数据和UI分开,使得应用程序的各个部分相互独立,增强了可维护性和可测试性。通过使用CounterViewModel作为中介,视图可以轻松地与模型交互,并在数据变化时自动更新。整个架构的设计不仅提升了代码的整洁度,也使得开发者能够更专注于各自的职责。


http://www.ppmy.cn/news/1535694.html

相关文章

Rust和Go谁会更胜一筹

在国内&#xff0c;我认为Go语言会成为未来的主流&#xff0c;因为国内程序员号称码农&#xff0c;比较适合搬砖&#xff0c;而Rust对心智要求太高了&#xff0c;不适合搬砖。 就个人经验来看&#xff0c;Go语言简单&#xff0c;下限低&#xff0c;没有什么心智成本&#xff0c…

python和r语言的区别是什么

在从事数据分析行业中&#xff0c;我们都会从R与Python当中进行选择&#xff0c;但是&#xff0c;从这两个异常强大、灵活好用的数据分析语中选择&#xff0c;却是非常难以选择的。 为了让大家能选择出更适合自己的语言&#xff0c;我们将两种语言进行简单的对比。 Stack Ove…

使用 Spring Boot 实现 JWT 生成与验证的自定义类

在现代 web 应用中&#xff0c;JWT&#xff08;JSON Web Tokens&#xff09;被广泛用于用户身份验证。本文将展示如何创建一个自定义的 JWT 生成与验证类 JwtPlus&#xff0c;该类使用对称加密算法&#xff0c;并支持灵活的配置选项。我们将通过以下步骤实现这个功能&#xff1…

【JavaEE】【多线程】进程与线程的概念

目录 进程系统管理进程系统操作进程进程控制块PCB关键属性cpu对进程的操作进程调度 线程线程与进程线程资源分配线程调度 线程与进程区别线程简单操作代码创建线程查看线程 进程 进程是操作系统对一个正在运行的程序的一种抽象&#xff0c;可以把进程看做程序的一次运行过程&a…

【PostgreSQL】提高篇——深入了解不同类型的 JOIN(INNER JOIN、LEFT JOIN、RIGHT JOIN、FULL JOIN)应用操作

1. JOIN 的基础概念 在 SQL 中&#xff0c;JOIN 是用于从两个或多个表中组合行的操作。JOIN 允许我们根据某些条件将表中的数据关联在一起。常见的 JOIN 类型包括&#xff1a; INNER JOIN&#xff1a;仅返回两个表中满足连接条件的行。LEFT JOIN&#xff08;或 LEFT OUTER JO…

美国静态住宅IP代理怎么定期更换?

在互联网使用中&#xff0c;P代理被广泛应用于许多方面&#xff0c;如网络安全测试、数据采集、访问受限制内容等。然而&#xff0c;为了维护隐私安全和避免被封禁&#xff0c;定期更换IP地址是必要的。特别是对于每个用户&#xff0c;定期更换IP地址更是至关重要。本文将探讨美…

网络通信——OSPF协议(基础篇)

这里基础是因为没有讲解OSPF中的具体算法过程&#xff0c;以及其中很多小细节。后续会更新。 目录 一.OSPF的基础信息 二.认识OSPF中的Router ID 三.OSPF中的三张表 四.OSPF中的度量方法&#xff08;计算开销值&#xff09; 五. OSPF选举DR和BDR&#xff08;就是这个区域…

wpf加载带材料的3D模型(下载的3D预览一样有纹理)

背景&#xff1a;最近真的是忙啊&#xff0c;累出汁水了 整体效果&#xff1a; 放大可以看清砖头&#xff1a; 1、需要自己准备好3D模型&#xff0c;比如我这里是下载的这里的3D Warehouse&#xff0c;下载Collada File格式文件 2、解压可以看到一个model.dae和材料的文件夹&…