MVC 即 Model-View-Controller 的缩写,就是 模型-视图-控制器, 也就是说一个标准的Web 应用程式是由这三部分组成的:
View 用来把数据以某种方式呈现给用户 Model 其实就是数据 Controller 接收并处理来自用户的请求,并将 Model 返回给用户
MVVM 是Model-View-ViewModel 的缩写,它是一种基于前端开发的架构模式,其核心是提供对View 和 View Model 的双向数据绑定,这使得View Model的状态改变可以自动传递给 View,这就是所谓的数据双向绑定。
- Model 代表模型,也就是数据
- View 代表视图, 也就是页面渲染的结果
- Controller 代表控制器,
- ViewModel 代表ViewModel,负责连接 View 和 Model的中间键
Vue.js 是一个提供 MVVM 风格的双向数据绑定的 Javascript 库,专注于View 层。它的核心是 MVVM 中的 VM,也就是 ViewModel。ViewModel负责连接 View 和 Model,保证视图和数据的一致性,这种轻量级的架构让前端开发更加高效、便捷。
MVC的痛点:
MVC 架构模式对于基础的应用来看起是OK的,更是符合软件架构的分层思想。 但实际上,随着H5 的不断发展,人们更希望使用H5 开发的应用能和Native 媲美,或者接近于原生App 体验效果,于是前端应用的复杂程度已不同往日,今非昔比。这时前端就暴露了三个重要的痛点问题:
- 开发者在代码中大量调用相同的 DOM API, 处理繁琐 ,操作冗余,使得代码难以维护。
- 大量的DOM 操作使页面渲染性能降低,加载速度变慢,影响用户体验。
- 当 Model 频繁发生变化,开发者需要主动更新到View ;当用户的操作导致 Model 发生变化,开发者同样需要将变化的数据同步到Model 中
这样的工作不仅繁琐,而且很难维护复杂多变的数据状态。
其实,早期jquery的出现就是为了前端能更简洁的操作DOM,但它只解决了第一个问题,后面的两个问题始终伴随着前端一直存在。
MVVM 的出现,完美的解决了以上三个问题。
MVVM 由 Model,View,ViewModel 三部分组成,Model 层代表数据模型,也可以在Model中定义数据修改和操作的业务逻辑;View 代表UI组件,它负责将数据模型转化成UI展现出来,ViewModel 是一个同步View 和 Model的对象。
在MVVM架构下,View 和 Model 之间并没有直接的联系,而是通过ViewModel进行交互,Model和ViewModel之间的交互是双向的, 因此View 数据的变化会同步到Model中,而Model 数据的变化也会立即反应到View上。
ViewModel 通过双向数据绑定把 View 层和 Model 层连接了起来,而View 和 Model 之间的同步工作完全是自动的,无需人为干涉,因此开发者只需关注业务逻辑,不需要手动操作DOM,不需要关注数据状态的同步问题,复杂的数据状态维护完全由 MVVM 来统一管理。