Flutter 项目实战 架构模式四

本文详细介绍了软件架构在大型系统设计中的作用,探讨了MVC、MVP和MVVM三种模式的区别,以及它们在Flutter中的具体实现,包括StatefulWidget的角色和数据流控制。
摘要由CSDN通过智能技术生成

维基百科软件架构

有关软件整体结构与组件的抽象描述,用于指导大型软件系统各个方面的设计。软件架构会包括软件组件、组件之间的关系,组件特性以及组件间关系的特性。软件架构可以和建筑物的架构相比拟。软件架构是构建计算机软件,开发系统以及计划进行的基础,可以列出开发团队需要完成的任务。

软件架构是在软件的基础架构上进行决策,一但决定后,再修改的代价很大。软件架构中的决策包括在软件设计时的一些特殊结构性选项,例如要控制太空船登陆艇的系统需要快速而且可靠,因此需要选择适合实时计算的语言,而且为了满足可靠度的需求,程序需要有数个冗余的复本,各复本运作在不同的硬件上,以便比对各程序的结果。

MVC模式(Model–view–controller)

软件架构模式

由三个部分组成 : 模型(Model)、视图(View)和控制器(Controller)

模型层 : 程序功能部分 , 包括数据管理和数据库设计

视图层 : 界面(Widget)

控制器 : 负责转发请求,对请求进行处理

MVP模式 (Model-view-presenter)

软件架构模式

在MVC的基础之上延伸出来的架构模式

由三个部分组成 : 模型(Model)、视图(View)和(Presenter)

模型层 : 包含着相关的业务逻辑

视图层 : 界面(Widget)

Presenter : 负责转发请求,对请求进行处理

MVVM模式Model–view–viewmodel

软件架构模式

将视图界面和业务逻辑分离开

由四个部分组成 : 模型(Model)、视图(View)、视图模型(ViewModel)、和 绑定器

模型层 : 内容的数据访问层

视图层 : 屏幕上看到的结构、布局和外观(UI)

视图模型 : 暴露的公共属性和视图的抽象, MVVM没有MVC模式的控制器,也没有MVP模式的presenter

绑定器 : 可以实现数据&UI双向绑定=>数据变更UI自动刷新,UI变更自动同步数据

/ Flutter MVC /

StatefulWiget 就相当于控制层(Controller)负责从模型层(Model)获取数据

View 就是被绑定到StatefulWiget里面的多个Widget

typedef void IMineModelCallBack(var _modelData);

abstract class IMimeModel {

void getMineData(IMineModelCallBack callBack);

}

class MineModel implements IMimeModel {

@override

void getMineData(IMineModelCallBack callBack) {

// TODO: implement getMineData

var _modelData = ‘首页改变后的数据’;

callBack(_modelData);

}

}

class MyHomePage extends StatefulWidget {

MyHomePage({Key? key, required this.title}) : super(key: key);

final String title;

@override

_MyHomePageState createState() => _MyHomePageState();

}

class _MyHomePageState extends State {

var _homeMineData=‘首页改变前的数据’;

void _changeMineData() {

MineModel _model=new MineModel();

_model.getMineData((_modelData) {

setState(() {

this._homeMineData=_modelData;

});

});

}

@override

Widget build(BuildContext context) {

return Scaffold(

appBar: AppBar(

title: Text(widget.title),

),

body: Center(

child: Column(

mainAxisAlignment: MainAxisAlignment.center,

children: [

Text(

‘$_homeMineData’,

style: Theme.of(context).textTheme.headline4,

),

],

),

),

floatingActionButton: FloatingActionButton(

onPressed: _changeMineData,

tooltip: ‘改变HomePage数据’,

child: Icon(Icons.add),

), // This trailing comma makes auto-formatting nicer for build methods.

);

}

}

/ Flutter MVP /

StatefulWidget 可以作为视图层负责处理界面呈现和用户交互

Presenter 处理业务,负责业务逻辑,发起数据请求(网络获取数据 | 本地获取数据)

Mode 数据源

调用顺序 View -> Presenter -> Model ,不可以反向调用,不可以跨级调用。

创建BaseModel

abstract class IModel {

//待扩展

}

abstract class BaseModel implements IModel {

//待扩展

}

///获取数据成功回调

typedef SuccessCallback = void Function(dynamic data);

///获取数据失败回调

typedef FailureCallback = void Function();

创建 BasePresenter

通过IModel建立 Presenter 和 Model的联系

import ‘package:flutter_splash_ios/mvp/BaseModel.dart’;

abstract class BasePresenter {

///模型层实例

M? _model;

M? get model => _model;

///通过控制层传递实例

///方便控制层从模型层获取数据

IModel createModel();

}

创建 BaseViewState

BaseView 用于传递Key 用于视图的刷新, 也可以传递其他类型的参数

key 分为 LocalKey (ValueKey、ObjectKey、UniqueKey) ") 和 GlobalKey

IView 建立 Presenter(控制层)  和  视图层 (View)  联系

import ‘package:flutter/material.dart’;

abstract class BaseView extends StatefulWidget {

BaseView({Key? key}) : super(key: key);

@override

BaseViewState createState() => getState();

///子类实现

BaseViewState getState();

}

abstract class BaseViewState extends State {

@override

Widget build(BuildContext context) {

return Scaffold(

///导航栏

appBar: buildAppBar(),

///内容区域

body: buildWidget(),

///内容区域背景颜色

backgroundColor: buildBodyColor(),

);

}

buildWidget();

buildAppBar() => null;

Color buildBodyColor() {

return Color(0xff00FFFFFF);

}

}

abstract class IView {

///开始加载数据

void startLoading();

///加载完成

void showLoadSuccess();

}

扩展 BasePresenter ,建立 Presenter(控制层)  和  视图层 (View)  联系

import ‘package:flutter_splash_ios/mvp/BaseModel.dart’;

import ‘package:flutter_splash_ios/mvp/BaseViewState.dart’;

abstract class IPresenter {

///通过视图层传递IView引用

void attachView(V? view);

///解除IView引用

void detachView();

}

abstract class BasePresenter<V extends IView, M extends IModel>

implements IPresenter {

///模型层实例

M? _model;

M? get model => _model;

///通过控制层传递实例到模型层

///方便控制层从模型层获取数据

IModel createModel();

///通过视图层传递实例到控制层

///方便控制层返回数据给视图层

V? _view;

V? get view => _view;

@override

void attachView(IView? view) {

_view = view as V?;

_model = createModel() as M?;

}

@override

void detachView() {

if (_view != null) {

_view = null;

}

}

}

通过 initState 函数向控制层 Presenter 传递IView

通过 dispose 函数解除对IView的引用

import ‘package:flutter/material.dart’;

import ‘package:flutter_splash_ios/mvp/BasePresenter.dart’;

abstract class BaseView extends StatefulWidget {

BaseView({Key? key}) : super(key: key);

@override

BaseViewState createState() => getState();

///子类实现

BaseViewState getState();

}

abstract class BaseViewState<V extends BaseView, P extends IPresenter>

extends State implements IView {

P? _presenter;

@override

void initState() {

// TODO: implement initState

_presenter = createPresenter();

if (_presenter != null) {

///传递IView引用到控制层(Presenter)

_presenter!.attachView(this);

}

super.initState();

}

P? createPresenter();

@override

void dispose() {

// TODO: implement dispose

if (_presenter != null) {

///解除IView引用

_presenter!.detachView();

}

super.dispose();

}

@override

Widget build(BuildContext context) {

return Scaffold(

///导航栏

appBar: buildAppBar(),

///内容区域

body: buildWidget(),

///内容区域背景颜色

backgroundColor: buildBodyColor(),

);

}

buildWidget();

buildAppBar() => null;

Color buildBodyColor() {

return Color(0xff00FFFFFF);

}

}

abstract class IView {

///开始加载数据

void startLoading();

///加载完成

void showLoadSuccess();

}

视图层、控制层、模型层 需要的 CallBack

import ‘package:flutter_splash_ios/mvp/BaseModel.dart’;

import ‘package:flutter_splash_ios/mvp/BasePresenter.dart’;

///视图层、控制层、模型层 需要实现的接口

abstract class CMineModel extends IModel {

///控制层调用

///获取数据后回传给控制层

loadData(SuccessCallback s, FailureCallback f);

}

abstract class CMinePresenter extends IPresenter {

///由视图层调用

///控制层进行加载数据

loadData();

}

abstract class CMineView {

///控制层返回的数据进行展示界面

loadData(data);

}

模型层 (Model) 实现

import ‘package:flutter_splash_ios/mvp/BaseModel.dart’;

import ‘package:flutter_splash_ios/mvp/buscal/BusCal.dart’;

class MMine extends BaseModel implements CMineModel {

@override

loadData(SuccessCallback s, FailureCallback f) {

// TODO: implement loadData

///通过接口回调将模型层数据传递给控制层

s(‘通过模型层加载的数据’);

}

}

控制层 (Presenter) 实现

import ‘package:flutter_splash_ios/mvp/BaseModel.dart’;

import ‘package:flutter_splash_ios/mvp/BasePresenter.dart’;

import ‘package:flutter_splash_ios/mvp/buscal/BusCal.dart’;

import ‘package:flutter_splash_ios/mvp/busimp/MMine.dart’;

class PMine extends BasePresenter<CMineView, CMineModel>

implements CMinePresenter {

@override

loadData() {

// TODO: implement loadData

///startLoading可以提示开始加载数据

view?.startLoading();

model?.loadData((data) {

//showLoadSuccess可以提示加载数据完成

view?.showLoadSuccess();

view?.loadData(data);

}, () {});

}

@override

IModel createModel() {

///传递模型层实例到控制层

return MMine();

}

}

视图层 (View) 调用控制层 (Presenter) 从模型层 (Model) 获取数据

class ImlBaseView extends BaseView {

@override

BaseViewState<BaseView, IPresenter> getState() {

// TODO: implement getState

return _ImlBaseViewState();

}

}

class _ImlBaseViewState extends BaseViewState<ImlBaseView, PMine>

implements CMineView {

var _homeMineData = ‘点击改变数据’;

@override

loadData(data) {

print(‘获取到的数据 $data’);

setState(() {

_homeMineData = ‘$data’;

});

}

///传递控制层实例

///视图层通过该实例从模型层加载数据

@override

PMine? createPresenter() {

return PMine();

}

@override

void startLoading() {

print(‘开始加载数据:startLoading’);

}

@override

最后

想要了解更多关于大厂面试的同学可以点赞支持一下,除此之外,我也分享一些优质资源,包括:Android学习PDF+架构视频+源码笔记高级架构技术进阶脑图、Android开发面试专题资料,高级进阶架构资料 这几块的内容。非常适合近期有面试和想在技术道路上继续精进的朋友。
《Android学习笔记总结+移动架构视频+大厂面试真题+项目实战源码》点击传送门,即可获取!

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值