前端中MVC和MVVM的区别:

待我称王封你为后i 2022-02-27 02:38 376阅读 0赞

之前是从事ios开发的,也遇到了MVC和MVVC的差别问题;下边的区别只是暂时的html这方面的总结,至于ios方面的差别还有待验证;

MVC

  1. **View:** UI布局,展示数据。

Model: 管理数据。

Controller: 响应用户操作,并将 Model 更新到 View 上。

  1. 这种 MVC 架构模式对于简单的应用来看起是OK 的,也符合软件架构的分层思想。
  2. 人们更希望使用H5 开发的应用能和Native 媲美,或者接近于原生App 的体验效果,于是前端应用的复杂程度已不同往日,今非昔比。这时前端开发就暴露出了三个痛点问题:
  • 开发者在代码中大量调用相同的 DOM API, 处理繁琐 ,操作冗余,使得代码难以维护。
  • 大量的DOM 操作使页面渲染性能降低,加载速度变慢,影响用户体验。
  • 当 Model 频繁发生变化,开发者需要主动更新到View ;当用户的操作导致 Model 发生变化,开发者同样需要将变化的数据同步到Model 中,这样的工作不仅繁琐,而且很难维护复杂多变的数据状态。

由此,出现了MVVM框架

MVVM

  1. MVVM Model,View,ViewModel 三部分构成,Model 层代表数据模型,也可以在Model中定义数据修改和操作的业务逻辑;View 代表UI 组件,它负责将数据模型转化成UI 展现出来,ViewModel 是一个同步View Model的对象。
  2. MVVM架构下,View Model 之间并没有直接的联系,而是通过ViewModel进行交互,Model ViewModel 之间的交互是双向的; 因此,View 数据的变化会同步到Model中,而Model 数据的变化也会立即反应到View 上。

ViewModel 通过双向数据绑定把 View 层和 Model 层连接了起来,而View 和 Model 之间的同步工作完全是自动的,无需人为干涉,因此开发者只需关注业务逻辑,不需要手动操作DOM, 不需要关注数据状态的同步问题,复杂的数据状态维护完全由 MVVM 来统一管理。

发表评论

表情:
评论列表 (有 0 条评论,376人围观)

还没有评论,来说两句吧...

相关阅读

    相关 MVC MVVM 区别

    mvc 和 mvvm 1. 传统的 mvc 架构通常是使用控制器更新模型,视图从模型中获取数据去渲染。当用户有输入时,会通过控制器去更新模型,通知视图进行更新,会造...

    相关 MVCMVVM区别

    MVC是后端分层开发概念 MVVM是前端视图层的概念 mvc处理过程:![MVC处理过程][MVC] MVVM:主要把每个页面分成了M、V、VM。其中VM是M、V之间

    相关 mvcmvvm区别

    前言 mvc和mvvm大概是个老生常谈的问题了,关于MVC和MVVM如此这般设计的原因以及我们应该如何思考一些相关的问题 --------------------

    相关 MVVMMVC区别

    一、MVVM是Model(数据层)-View(视图层)-ViewModel(视图模板)的简写。 本质上是MVC的改进版,MVVM就是将VIew中的状态和行为抽象化,将视图中