![](https://img.haomeiwen.com/i10758861/cfe42cefaf9c66db.jpg)
MVC
MVC 即 Model-View-Controller 的缩写,就是 模型-视图-控制器 , 也就是说一个标准的Web 应用程式是由这三部分组成的:
-
View 用来把数据以某种方式呈现给用户。
-
Model 其实就是数据。
-
Controller 接收并处理来自用户的请求,并将 Model 返回给用户。
MVC的一般流程是这样的:View(界面)触发事件-->Controller(业务)处理了业务,然后触发了数据更新-->更新了Model的数据-->Model(带着数据)回到了View-->View更新数据
![](https://img.haomeiwen.com/i10758861/7bede5b1349f86f3.png)
如图MVC指:
M:Model层
V:View视图层
C:Controller层(router.js Controller)
但随着前端日益复杂,MVC的不足:
-
1、开发者在代码中大量调用相同的 DOM API, 处理繁琐 ,操作冗余,使得代码难以维护。
-
2、大量的DOM 操作使页面渲染性能降低,加载速度变慢,影响用户体验。
-
3、当 Model 频繁发生变化,开发者需要主动更新到View ;当用户的操作导致 Model 发生变化,开发者同样需要将变化的数据同步到Model 中,这样的工作不仅繁琐,而且很难维护复杂多变的数据状态。
MVVM
视图层的分层开发思想
MVVM
由 Model,View,ViewModel 三部分构成,Model 层代表数据模型,也可以在Model中定义数据修改和操作的业务逻辑;View 代表UI 组件,它负责将数据模型转化成UI 展现出来,ViewModel 是一个同步View 和 Model的对象。
![](https://img.haomeiwen.com/i10758861/c767a6916730b752.png)
在MVVM架构下,View 和 Model 之间并没有直接的联系,而是通过ViewModel进行交互,Model 和 ViewModel 之间的交互是双向的, 因此View 数据的变化会同步到Model中,而Model 数据的变化也会立即反应到View 上。
ViewModel 通过双向数据绑定把 View 层和 Model 层连接了起来,而View 和 Model 之间的同步工作完全是自动的,无需人为干涉,因此开发者只需关注业务逻辑,不需要手动操作DOM, 不需要关注数据状态的同步问题,复杂的数据状态维护完全由 MVVM 来统一管理。
网友评论