MVC和MVVC的区别

一、MVC (Model-View-Controller)

定义:Model(模型)-View(视图)-Controller(控制器),是一种将业务逻辑、数据、界面显示分离开来的软件设计模式,更偏向于后端。
目的:将模型和和视图代码分离,让同一个程序实现不同的表现方式。
在这里插入图片描述

MVC 编程模式

MVC 是一种使用 MVC(Model View Controller 模型-视图-控制器)设计创建 Web 应用程序的模式:
Model(模型)表示应用程序核心(如数据库)。
View(视图)显示效果(HTML页面)。
Controller(控制器)处理输入(业务逻辑)。

MVC 模式同时提供了对 HTML、CSS 和 JavaScript 的完全控制。
Model(模型)是应用程序中用于处理应用程序数据逻辑的部分。
  通常模型对象负责在数据库中存取数据。
View(视图)是应用程序中处理数据显示的部分。
  通常视图是依据模型数据创建的。
Controller(控制器)是应用程序中处理用户交互的部分。
  通常控制器负责从视图读取数据,控制用户输入,并向模型发送数据。

二、MVVC(Model-View-ViewModel)

MVVM即Model-View-ViewModel的简写。即模型-视图-视图模型。
模型(Model)指的是后端传递的数据。
视图(View)指的是所看到的页面。
视图模型(ViewModel)是mvvm模式的核心,它是连接view和model的桥梁。
它有两个方向:
一是将模型(Model)转化成视图(View),即将后端传递的数据转化成所看到的页面。实现的方式是:数据绑定。
二是将视图(View)转化成模型(Model),即将所看到的页面转化成后端的数据。实现的方式是:DOM 事件监听。
这两个方向都实现的,我们称之为数据的双向绑定。

MVVM模式的组成部分

模型
模型是指代表真实状态内容的领域模型(面向对象),或指代表内容的数据访问层(以数据为中心)。

视图
就像在MVC和MVP模式中一样,视图是用户在屏幕上看到的结构、布局和外观(UI)。

视图模型
视图模型是暴露公共属性和命令的视图的抽象。MVVM没有MVC模式的控制器,也没有MVP模式的presenter,有的是一个绑定器。在视图模型中,绑定器在视图和数据绑定器之间进行通信。

绑定器
声明性数据和命令绑定隐含在MVVM模式中。在Microsoft解决方案堆中,绑定器是一种名为XAML的标记语言。绑定器使开发人员免于被迫编写样板式逻辑来同步视图模型和视图。在微软的堆之外实现时,声明性数据绑定技术的出现是实现该模式的一个关键因素。

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 操作使页面渲染性能降低,加载速度变慢,影响用户体验

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: MVCMVVC 是两种常见的软件架构模式,主要用于构建用户界面。 MVC 是 Model-View-Controller 的缩写,是指模型-视图-控制器的架构。在 MVC 架构中,用户界面被划分为三个部分: - Model(模型):表示应用程序的状态和业务逻辑。 - View(视图):表示应用程序的用户界面,负责将模型的数据呈现给用户。 - Controller(控制器):负责响应用户的操作,接收用户的输入并根据输入更新模型和视图。 MVVC 是 Model-View-ViewModel 的缩写,是 MVC 的变体。MVVC 架构中多了一个 ViewModel 层,它负责将模型的数据转化为视图能够使用的格式。ViewModel 与 View 和 Model 之间的交互是通过数据绑定来实现的,ViewModel 不直接操作视图,而是通过数据绑定将模型的状态呈现给视图。 MVCMVVC区别在于,MVVC 多了一个 ViewModel 层,ViewModel 负责将模型的数据转化为视图能够使用的格式,同时通过数据绑定将模型的状态呈现给视图。由于 ViewModel 不直接操作视图,因此 MVVC 的代码 ### 回答2: MVCMVVC是两种常见的软件架构模式,用于将应用程序的不同部分分离开来,提供更好的可维护性和扩展性。 MVC(Model-View-Controller)是一种经典的软件架构模式,将应用程序分为三个组件:模型(Model)、视图(View)和控制器(Controller)。模型负责处理数据逻辑,视图负责用户界面的展示,控制器负责处理用户输入和业务逻辑。MVC的主要特点是逻辑清晰、分工明确,能够有效分离关注点,提高代码的可维护性。然而,由于控制器负责处理用户输入和业务逻辑,在复杂的应用中往往导致控制器变得臃肿,难以维护。 MVVM(Model-View-ViewModel)是一种相对较新的软件架构模式,将应用程序分为三个组件:模型(Model)、视图(View)和视图模型(ViewModel)。模型依然负责处理数据逻辑,视图负责用户界面的展示,而视图模型负责将模型数据转化为视图所需的格式,并处理用户的操作请求,然后将结果反馈给模型。MVVM的主要特点是数据双向绑定,视图模型与视图的绑定使得数据的更新可以自动反映到视图上,大大简化了视图和模型之间的通信,提高了代码的可维护性和可测试性。 区别MVC和MVVM的关键在于视图和模型之间的通信方式。在MVC中,视图通过控制器与模型进行通信,而在MVVM中,视图模型通过双向数据绑定与模型进行通信。MVVM通过数据绑定的方式,实现了视图和模型之间的解耦,降低了代码的复杂性。此外,MVVM还提供了命令绑定的机制,将用户操作转化为模型中的具体业务逻辑,进一步简化了代码的编写。 总之,MVC和MVVM都是用于分离应用程序中不同部分的架构模式,MVC较为传统,MVVM相对较新且强调数据绑定,通过不同的通信方式实现了代码的可维护性和可测试性的提升。选择使用哪种架构模式应根据具体的项目需求和开发团队的熟悉程度进行评估。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值