写在前面
在Flutter中实现MVVM(Model-View-ViewModel)架构是为了将UI(视图)与业务逻辑(模型和视图模型)分离,提高代码的可维护性和可读性。
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});
@override
Widget build(BuildContext context) {
return MaterialApp(
title: 'Flutter MVVM Example',
home: ChangeNotifierProvider(
create: (context) => CounterViewModel(CounterModel()),
child: MyHomePage(),
),
);
}
}
main
函数: 应用程序的入口,使用runApp
启动MyApp
。MyApp
类: MaterialApp
用于创建一个Material风格的应用。ChangeNotifierProvider
来创建CounterViewModel
实例并将其提供给MyHomePage
。这样,MyHomePage
及其子组件就能访问CounterViewModel
。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组件能够监听到数据的变化。_counterModel
是CounterModel
的实例,负责持有计数数据。counter
: 一个getter,提供当前计数值。incrementCounter
: 增加计数值的方法,并调用notifyListeners()
来通知UI进行更新。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});
@override
State<MyHomePage> createState() => MyHomePage_State();
}
class MyHomePage_State extends State<MyHomePage> {
@override
Widget 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),
),
);
}
}
MyHomePage
类: build
方法: Provider.of<CounterViewModel>(context)
获取CounterViewModel
的实例。Scaffold
,显示应用的结构。FloatingActionButton
调用incrementCounter
方法以增加计数值。Model.dart
class CounterModel {
int _counter = 0;
int get counter => _counter;
void increment() {
_counter++;
}
}
CounterModel
类: _counter
是一个私有变量,用于存储计数值。counter
: 一个getter,提供对计数值的访问。increment
: 方法用于增加计数值。notifyListeners()
通知视图更新UI。Provider
包使得数据绑定变得简单。通过ChangeNotifier
和Provider
,视图可以非常方便地监听数据变化。在Flutter中实现MVVM架构的关键在于利用Provider
进行状态管理,将数据和UI分开,使得应用程序的各个部分相互独立,增强了可维护性和可测试性。通过使用CounterViewModel
作为中介,视图可以轻松地与模型交互,并在数据变化时自动更新。整个架构的设计不仅提升了代码的整洁度,也使得开发者能够更专注于各自的职责。