当前位置: 首页 > news >正文

web前端面试-- MVC、MVP、MVVM 架构模式对比

MVC、MVP、MVVM 架构模式对比

基本概念

这三种都是用于分离用户界面(UI)与业务逻辑的架构模式,旨在提高代码的可维护性、可测试性和可扩展性。

1. MVC (Model-View-Controller)

核心结构

  • Model:数据模型和业务逻辑
  • View:用户界面展示
  • Controller:接收用户输入并协调Model和View

数据流向

用户操作 → View → Controller → Model → (通知) → View更新

特点

  • View可以直接访问Model
  • Controller相对"厚重",包含大量业务逻辑
  • 常用于Web开发(如Spring MVC、Ruby on Rails)

2. MVP (Model-View-Presenter)

核心结构

  • Model:数据模型和业务逻辑
  • View:用户界面(被动视图)
  • Presenter:中间人,处理View逻辑

数据流向

用户操作 → View → Presenter → Model → Presenter → View

特点

  • View不能直接访问Model
  • Presenter持有View引用
  • View是被动的,只负责显示
  • 更易于单元测试(如Android早期开发常用)

3. MVVM (Model-View-ViewModel)

核心结构

  • Model:数据模型
  • View:用户界面
  • ViewModel:View的抽象(包含状态和命令)

数据流向

用户操作 → View → ViewModel → Model → (数据绑定) → View自动更新

特点

  • 通过数据绑定实现自动更新
  • ViewModel不知道View的存在
  • 最适合数据驱动型应用(如WPF、Vue、Angular)

对比表格

特性MVCMVPMVVM
View职责主动被动声明式
更新机制Controller手动更新Presenter手动更新数据绑定自动更新
耦合度View知道ModelView不知道ModelView不知道Model
测试难度较难(Controller厚重)较易最易(ViewModel独立)
典型应用传统Web应用Windows Forms应用现代前端框架
通信方向双向View→Presenter单向双向(通过绑定)

演进关系

MVC → MVP → MVVM

随着应用复杂度增加,架构模式不断演进,分离越来越彻底,测试越来越容易。

如何选择

  • 简单项目:MVC足够
  • 需要高测试性:MVP或MVVM
  • 数据驱动UI:优先MVVM
  • 平台支持:根据框架选择(如Android可用MVP/MVVM,Vue/Angular用MVVM)
http://www.lryc.cn/news/581185.html

相关文章:

  • 硬件嵌入式工程师学习路线终极总结(二):Makefile用法及变量——你的项目“自动化指挥官”!
  • WEB攻防-文件包含LFIRFI伪协议编码算法无文件利用黑白盒
  • Go语言的web框架--gin
  • NX二次开发——NX二次开发-检查点是否在面上或者体上
  • MyChrome.exe与Selenium联动避坑指南:User Data目录冲突解决方案
  • 一篇文章快速入门TypeScript基础语法
  • 超详细yolov8/11-segment实例分割全流程概述:配置环境、数据标注、训练、验证/预测、onnx部署(c++/python)详解
  • Zigbee/Thread
  • Xshell使用技巧
  • 七牛云前端面试题及参考答案 (上)
  • 2025使用VM虚拟机安装配置Macos苹果系统下Flutter开发环境保姆级教程--下篇
  • C语言socket编程-补充
  • 测试时学习(TTT):打破传统推理界限的动态学习革命
  • vue router 里push方法重写为什么要重绑定this
  • JVM与JMM
  • RAL-2025 | 清华大学数字孪生驱动的机器人视觉导航!VR-Robo:面向视觉机器人导航与运动的现实-模拟-现实框架
  • rpgmaker android js常用属性解析
  • UI前端大数据可视化实战:如何设计高效的数据交互界面?
  • FLAN-T5:规模化指令微调的语言模型
  • 职坐标:AI图像识别NLP推荐算法实战
  • 【学习笔记】MySQL技术内幕InnoDB存储引擎——第5章 索引与算法
  • 针对工业触摸屏维修的系统指南和资源获取途径
  • Spring Bean 控制销毁顺序的方法总结
  • 408第三季part2 - 计算机网络 - 计算机网络分层结构
  • 【性能优化与架构调优(二)】高性能数据库设计与优化
  • 从零开始开发纯血鸿蒙应用之探析仓颉语言与ArkTS的差异
  • 深入理解Qt的SetWindowsFlags函数
  • Eureka、Nacos、LoadBalance、OpenFeign​之间的区别联系和协作 (附代码讲解)
  • ROS 的 move_base 模块介绍
  • 爬虫-web请求全过程