之前是从事ios开发的,也遇到了MVC和MVVC的差别问题;下边的区别只是暂时的html这方面的总结,至于ios方面的差别还有待验证;
MVC
View: UI布局,展示数据。
Model: 管理数据。
Controller: 响应用户操作,并将 Model 更新到 View 上。
这种 MVC 架构模式对于简单的应用来看起是OK 的,也符合软件架构的分层思想。
人们更希望使用H5 开发的应用能和Native 媲美,或者接近于原生App 的体验效果,于是前端应用的复杂程度已不同往日,今非昔比。这时前端开发就暴露出了三个痛点问题:
- 开发者在代码中大量调用相同的 DOM API, 处理繁琐 ,操作冗余,使得代码难以维护。
- 大量的DOM 操作使页面渲染性能降低,加载速度变慢,影响用户体验。
- 当 Model 频繁发生变化,开发者需要主动更新到View ;当用户的操作导致 Model 发生变化,开发者同样需要将变化的数据同步到Model 中,这样的工作不仅繁琐,而且很难维护复杂多变的数据状态。
由此,出现了MVVM框架
MVVM
MVVM 由 Model,View,ViewModel 三部分构成,Model 层代表数据模型,也可以在Model中定义数据修改和操作的业务逻辑;View 代表UI 组件,它负责将数据模型转化成