前端框架模式MVC、MVP和MVVM的区别

1. 概述

三种常见的前端架构模式——MVC、MVP、MVVM

通过分离关注点改进代码的组织方式。

  • MVC模式是MVP、MVVM模式的基础

    • 这两种模式更像是MVC模式的优化改良版
    • 他们三个的MV(model,view)相同,不同的是MV之间的纽带部分

2. MVC

  • 允许在不改变视图的情况下,改变视图对用户输入的响应方式
  • 用户对View的操作交给了Controller处理
    • 在Controller中响应View的事件调用Model的接口对数据进行操作
    • 一旦Model发生变化便通知相关视图进行更新。

(1)视图(View):视图层
(2)控制器(Controller):业务逻辑层
(3)模型(Model):数据层
在这里插入图片描述
View 传送指令到 Controller
Controller 完成业务逻辑后,要求 Model 改变状态
Model 将新的数据发送到 View,用户得到反馈

(MVC模式可以这样理解成:html=>view,js=>controller)

js负责处理用户与应用的交互:

  • 响应对view的操作(对事件的监听)
  • 调用Model对数据进行操作
  • 完成model与view的同步(根据model的改变,通过选择器对view进行操作)
  • 将js的ajax当做Model,也就是数据层,通过ajax从服务器获取数据

接受用户指令时,MVC 可以分成两种方式:
(1)一种是通过 View 接受指令,传递给 Controller在这里插入图片描述 (2)另一种是直接通过controller接受指令在这里插入图片描述

2. MVP

MVP模式将 Controller 改名为 Presenter,同时改变了通信方向。

在这里插入图片描述

  1. 双向通信

  2. View 与 Model 通过 Presenter 间接传递

  3. View 很薄不部署任何业务逻辑,称为"被动视图"(Passive View),即没有任何主动性,而 Presenter很厚,部署所有逻辑

3. MVVM

MVVM与MVC最大的区别就是:实现了View和Model的自动同步

也就是当Model的属性改变时,该属性对应View层显示会自动改变,我们无需手动操作Dom元素来改变View的显示

  • html部分相当于View层,View通过模板语法将数据渲染进DOM元素,当ViewModel对Model进行更新时,通过数据绑定更新到View。

  • data相当于Model层,而ViewModel层的核心是Vue中的双向数据绑定,即Model变化时VIew可以实时更新,View变化也能让Model发生变化。

整体看来,MVVM比MVC精简很多,不仅简化了业务与界面的依赖,还解决了数据频繁更新的问题,不用再用选择器操作DOM元素。

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值