IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 开发测试 -> MVC、MVP和MVVM模式的基础认识 -> 正文阅读

[开发测试]MVC、MVP和MVVM模式的基础认识

MVC、MVP和MVVM的基础认识和区别

MVC、MVP和MVVM都是一种设计思想,其核心宗旨就是让代码层次更清晰、降低耦合、提高复用性,各司其职。

其中MVC思想一般运用在全栈开发上,MVVM思想则一般运用在前端开发上。
因为只是一种思想,你想在前端使用MVC也是可以的,总之你想在哪儿用上这些思想都行。

先大体上了解一下MVC和MVVM常见的使用场景。
下面为使用node.js搭建的服务和web页面的整体架构图:
在这里插入图片描述

一、MVC 设计模式

1. 定义

MVC 即:Model(模型)View(视图)Controller(控制器),也叫三层架构。

  • Model:模型,及数据,一般为一个存取数据的对象。
  • View:视图,及页面展示,负责将模型中的数据进行可视化展示。
  • Controller: 控制器,及事件方法,负责控制模型和视图,它控制数据流向模型对象,并在数据变化时更新视图。
    在这里插入图片描述

2. 特点

优点

  • 耦合性低,视图模型控制器三者相互分离,这样就允许更改视图层代码而不用重新编译模型和控制器代码。
  • 重用性高,多个视图能共享一个模型。
  • 可维护性高,分离视图层和业务逻辑层也使得WEB应用更易于维护和修改。
  • 前后端可以分工作业,提升开发效率。

缺点

  • 不适合小型应用程序。
  • 增加系统结构和实现的复杂性。
  • 控制层和表现层有时会过于紧密,导致没有真正分离和重用。

二、MVP 设计模式

1. 定义

MVP 即:Model(模型)View(视图)Presenter(控制中心),一般在.net开发以及Android和iOS的原生开发中应用,MVP简化了MVC中数据的交叉交互。

  • Model:模型,及数据,一般为一个存取数据的对象。
  • View:视图,及页面展示,负责将模型中的数据进行可视化展示。
  • Presenter: 控制中心,model和view的交付都通过presenter来进行。

在这里插入图片描述

2. 特点

Presenter需要处理业务逻辑并且处理页面参数获取及显示更新,只适合小型项目,大项目会导致Presenter非常臃肿。
mvp更像是mvc和mvvm中间的一个过渡思想,为了处理Presenter臃肿问题,于是有了VM的数据双向绑定,处理了获取和更新页面数据的问题。

三、MVVM 设计模式

1. 定义

MVVM 即:Model(模型)View(视图)ViewModel(视图-数据)

  • Model:模型,它是与应用程序的业务逻辑相关的数据的封装载体。
  • View:视图,专注于界面的显示和渲染。
  • ViewModel: 视图-数据,它是View和Model的粘合体,负责View和Model的交互和协作。

MVVM 设计模式将view层的布局控件和model层的数据通过中间桥梁viewModel实现双向绑定,而view和model没有直接的交互,实现了view和model的解耦。
在这里插入图片描述

2. 特点

MVVM模式和MVC模式一样,主要目的是分离视图(View)和模型(Model),MVVM本质上是MVC 的改进版。

优点

  • 数据双向绑:减少基础代码,提高开发效率(由vm层提供,vm是MVVM的核心)。
  • 低耦合:视图(View)可以独立于Model变化和修改,一个ViewModel可以绑定到不同的"View"上,当View变化的时候Model可以不变,当Model变化的时候View也可以不变。
  • 可重用性:你可以把一些视图逻辑放在一个ViewModel里面,让很多view重用这段视图逻辑。
  • 独立开发:开发人员可以专注于业务逻辑和数据的开发(ViewModel),设计人员可以专注于页面设计,使用Expression Blend可以很容易设计界面并生成xml代码。
  • 界面测试:界面素来是比较难于测试的,而现在测试可以针对ViewModel来写。

缺点

  • 数据双向绑定增加了大量的内存开销,增加了程序的编译时间,项目越大内存开销越大。
  • 数据绑定使得 Bug 很难被调试。你看到界面异常了,有可能是你 View 的代码有 Bug,也可能是 Model 的代码有问题。
  开发测试 最新文章
pytest系列——allure之生成测试报告(Wind
某大厂软件测试岗一面笔试题+二面问答题面试
iperf 学习笔记
关于Python中使用selenium八大定位方法
【软件测试】为什么提升不了?8年测试总结再
软件测试复习
PHP笔记-Smarty模板引擎的使用
C++Test使用入门
【Java】单元测试
Net core 3.x 获取客户端地址
上一篇文章      下一篇文章      查看所有文章
加:2021-08-18 12:59:46  更:2021-08-18 13:00:05 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年4日历 -2024/4/28 4:46:28-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码