MVVM模式的优点以及与MVC模式的区别

MVC模式

MVC是应用最广泛的软件架构之一,一般MVC分为:Model(模型),View(视图),Controller(控制器)。 这主要是基于分层的目的,让彼此的职责分开.View一般用过Controller来和Model进行联系。Controller是Model和View的协调者,View和Model不直接联系。基本都是单向联系。
在这里插入图片描述

  • Model: 模型(用于封装与应用程序的业务逻辑相关的数据以及对数据的处理方法)
  • View: 视图(渲染页面)
  • Controller: 控制器(M和V之间的连接器,用于控制应用程序的流程,及页面的业务逻辑)
MVC的特点

MVC模式的特点在于实现关注点分离,即应用程序中的数据模型与业务和展示逻辑解耦。在客户端web开发中,就是将模型(M-数据、操作数据)、视图(V-显示数据的HTML元素)之间实现代码分离,松散耦合,使之成为一个更容易开发、维护和测试的客户端应用程序。

  • View 传送指令到 Controller ;
  • Controller 完成业务逻辑后,要求 Model 改变状态 ;
  • Model 将新的数据发送到 View,用户得到反馈。

MVVM模式

MVVM最早由微软提出来,它借鉴了桌面应用程序的MVC思想,在前端页面中,把Model用纯JavaScript对象表示,View负责显示,两者做到了最大限度的分离,把Model和View关联起来的就是ViewModel。
ViewModel负责把Model的数据同步到View显示出来,还负责把View的修改同步回Model
View 和 Model 之间的同步工作完全是自动的,无需人为干涉(由viewModel完成)
因此开发者只需关注业务逻辑,不需要手动操作DOM, 不需要关注数据状态的同步问题,复杂的数据状态维护完全由 MVVM 来统一管理。
在这里插入图片描述

MVVM模式的优点

1、低耦合:MVVM模式中,数据是独立于UI的,ViewModel只负责处理和提供数据,UI想怎么处理数据都由UI自己决定,ViewModel不涉及任何和UI相关的事,即使控件改变(input换成p),ViewModel几乎不需要更改任何代码,专注自己的数据处理就可以了

2.自动同步数据:ViewModel通过双向数据绑定把View层和Model层连接了起来,View和Model这两者可以自动同步。程序员不需要手动操作DOM, 不需要关注数据状态的同步问题,MVVM 统一管理了复杂的数据状态维护

3、可重用性:你可以把一些视图逻辑放在一个ViewModel里面,让很多view重用这段视图逻辑。

4、独立开发:开发人员可以专注于业务逻辑和数据的开发(ViewModel),设计人员可以专注于页面设计。

5、可测试:ViewModel里面是数据和业务逻辑,View中关注的是UI,这样的做测试是很方便的,完全没有彼此的依赖,不管是UI的单元测试还是业务逻辑的单元测试,都是低耦合的

MVVM模式与MVC模式的区别

mvc 和 mvvm 其实区别并不大。都是一种设计思想,主要区别如下:
1.mvc 中 Controller演变成 mvvm 中的 viewModel

2.mvvm 通过数据来驱动视图层的显示而不是节点操作。

3.mvc中Model和View是可以直接打交道的,造成Model层和View层之间的耦合度高。而mvvm中Model和View不直接交互,而是通过中间桥梁ViewModel来同步

4.mvvm主要解决了:mvc中大量的DOM 操作使页面渲染性能降低,加载速度变慢,影响用户体验。

在这里插入图片描述

  • 10
    点赞
  • 86
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
MVVM 模式是一种软件架构模式,它包括三个部分:模型(Model)、视图(View)和视图模型(ViewModel),是一种基于数据绑定技术的前端开发模式MVVM 模式的核心思想是将视图和数据绑定在一起,通过视图模型来实现视图和数据的分离。 MVVM 模式MVC 模式有以下区别: 1. 视图和模型之间的通信方式不同:在 MVC 模式中,视图和模型之间是通过控制器来进行通信的,而在 MVVM 模式中,视图和视图模型之间是通过数据绑定来进行通信的。 2. 视图模型的作用不同:在 MVC 模式中,控制器主要负责协调视图和模型之间的通信,而在 MVVM 模式中,视图模型则充当了控制器和模型之间的桥梁,负责将模型数据绑定到视图上,并通过视图模型来实现视图和数据的分离。 3. 视图的实现方式不同:在 MVC 模式中,视图通常是由 HTML 页面和 CSS 样式来实现的,而在 MVVM 模式中,视图则通常是由 HTML 页面、CSS 样式和 JavaScript 代码(包括视图模型)来实现的。 MVVM 模式优点包括: 1. 实现了视图和数据的分离,降低了代码耦合度,使代码更加清晰和易于维护。 2. 通过数据绑定技术,可以自动更新视图,减少了代码量和开发时间。 3. 视图模型可以作为数据接口,使得开发人员可以更加方便地测试和调试代码。 综上所述,MVVM 模式是一种基于数据绑定技术的前端开发模式,通过视图模型来实现视图和数据的分离,与 MVC 模式相比,具有更加清晰和易于维护的代码结构和更高的开发效率。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值