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

MVC、MVP、MVVM 架构 笔记

个人笔记 by Ai, 如有错误 望指正谢谢


一、主流 Web MVC

流程:用户操作 →Controller-请求读/改数据 →Model-执行请求并返回结果 →Controller-传递结果→View-根据结果更新页面

这里的 View不依赖Model行为,但大概率依赖数据契约,简单说就是 Model 负责规定数据“有什么”,View 则根据这些数据的格式来决定页面“怎么显示”。属于耦合度偏低的数据耦合。


二、经典 MVC

流程①:View-主动监听 →Model-数据变动后通知 →View-拉取变动后的数据更新页面

流程②:用户操作 →Controller-请求读/改数据 →Model-变更数据,通知观察者(这里指的View)

View持有Model引用,但只读不写,同上面本质上是一回事,数据耦合、轻耦合。


三、MVP

流程:用户操作 →Presenter-读/改数据 →Model-返回结果 →Presenter-操控→View

和上面的主流 Web MVC非常相似,不同是View:

  • ViewModel完全无耦合。
  • View更抽象更通用化,它可能提供一系列元素或调用接口,供Presenter自由实现

举例:一个通用的账户登录页面,页面包含标题、背景图、账号密码输入框、登录按钮,以及错误弹窗。采用 MVP 架构时,View 只需定义好这些 UI 元素,可能再封装一个弹窗调用方法就完了。它就像一个纯静态界面,只负责展示视图本身,完全不理解按钮、输入框对应的业务逻辑,具体功能实现全部交由 Presenter 处理。

如果换成上面主流的 Web MVC,情况就大不一样了: View清楚自己是登录界面。用户点击登录后,它会把账号和密码传给 Controller 做校验,拿到结果后自主判断对错,校验失败就弹出提示。同时它还会主动校验输入内容,一旦发现账号或密码为空,立刻弹窗提醒。还有页面标题显示的是什么,View 也会主动问问 Controller 。


四、MVVM

流程:

用户操作 View → ViewModel处理 → Model更新 → ViewModel更新 → View自动刷新

数据驱动视图!自动同步!View ← 双向绑定 → ViewModel

和 MVP 中的 View 一样,MVVM 的 View 也完全不关心业务逻辑。用户产生操作时,View 仅将事件传递给 ViewModel,由 ViewModel 全权处理业务逻辑与数据加工。二者最大的不同在于,MVVM 额外增加了数据绑定机制:View 在初始化阶段就会和专属的 ViewModel 完成绑定,此后只要 ViewModel 内部数据发生变化,View 便会自动同步展示最新内容。

http://www.rkmt.cn/news/1422725.html

相关文章:

  • BERT Miniatures系列解析:为什么BERT uncased L-12 H-256 A-4适合资源受限环境
  • 在OpenClawAgent工作流中无缝接入Taotoken多模型
  • Irodori-TTS-500M-v2未来路线图:日语语音合成的下一步发展方向
  • 告别手绘!用Unity Tilemap快速搭建2D像素风地图(附官方拓展包下载)
  • 【Lindy简历筛选自动化实战指南】:20年HR Tech专家亲授,3步搭建零代码筛选系统(附5个避坑清单)
  • Speechless微博备份工具:5分钟快速导出PDF的终极指南
  • 2026年深圳小程序开发外包公司靠谱公司一览,值得收藏 - 软件测评师
  • 实测OpenHuman:看完源码我才懂,它凭什么碾压市面上90%的AI Agent|开发者视角复盘
  • GEO贴牌代理需要满足的条件?有哪些功能? - GEO贴牌代理
  • 2026年Q2苏州企业GEO服务商选型测评报告:谁才是AI搜索时代的真正领跑者? - 品牌推广大师
  • 3分钟快速解除课堂控制:JiYuTrainer极域电子教室操作自由完整指南
  • 2026年公安民警心理健康测评系统厂商推荐 - 健成星云
  • AI语音工具产业落地推演:声线APP的功能适配与场景实践 - 品牌评测官
  • 如何用Mac Mouse Fix让你的普通鼠标变身Mac效率神器
  • 暗黑2存档编辑器终极指南:5分钟掌握d2s-editor可视化编辑
  • 原料药设备B2B推广避坑指南!反应釜、储罐、配液罐渠道选型 - 品牌推荐大师1
  • 基于IMU与触觉反馈的穿戴式膝关节动态外翻矫正系统构建
  • 开发者如何参与贡献——从SIG参与到核心维护者的完整路径
  • 保姆级教程:在CentOS7.9单节点OpenStack上,搞定虚拟机SSH访问(附浮动IP配置全流程)
  • 用Scratch与Makey Makey制作体感Flappy Bird:编程与硬件的创意融合
  • 2026年电气机柜及成套解决方案采购指南:聚焦配电柜、不锈钢柜与温控技术 - 资讯纵览
  • 深度拆解Opus 4.8:Dynamic Workflows重构AI开发模式
  • 深度拆解:NVIDIA-Ising-Calibration-1-35B-A3B的两阶段训练与72.5K数据集奥秘 [特殊字符]
  • 反应釜保温施工专业团队:提供高温设备保温设计与安装 - 品牌推荐大师
  • Qwopus3.6-27B-v2-MTP-GGUF模型原理入门:从基础架构到推理优化
  • Visual Syslog Server:Windows平台上的网络日志可视化监控利器
  • 科研级微根管/微根窗根系观测系统|根系生长动态原位|植物根系生长监测系统选购|DETXA大耳厂家实力测评 - 品牌推荐大师
  • 综合算法 VII | 问题分类与解法
  • 【Claude政策合规生死线】:从GDPR到中国《生成式AI服务管理暂行办法》,跨法域适配实战指南
  • two aunts and four sister