对MVVM和MVC开发模式的理解

对MVVM和MVC开发模式的理解

1、MVVM

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

2、MVC

MVC是包括model数据层、view视图层、controller控制层。各部分之间的通信都是单向的。
model,即数据模型,负责数据相关的任务,包括对数据的增删改查。
view,即视图层,即用户能看得到的界面。
Controller,即控制器,负责监听用户事件,然后调用 model 和 view 更新数据和视图。

在这里插入图片描述

3、MVVM与MVC的区别

1.mvc 中 Controller演变成 mvvm 中的 viewModel。
2.mvvm 通过数据来驱动视图层的显示而不是节点操作。
3.mvc中Model和View是可以直接打交道的,造成Model层和View层之间的耦合度高。而mvvm中Model和View不直接交互,而是通过中间桥梁ViewModel来同步。
4.mvvm主要解决了mvc中大量的DOM操作使页面渲染性能降低,加载速度变慢,影响用户体验。

猜你喜欢

转载自blog.csdn.net/DZQ1223/article/details/131415234