对MVVM和MVC开发模式的理解
- 1、MVVM
- 2、MVC
- 3、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操作使页面渲染性能降低,加载速度变慢,影响用户体验。