MVC、MVP、MVVM 模式

本文涉及的产品
Redis 开源版,标准版 2GB
推荐场景:
搭建游戏排行榜
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 Tair(兼容Redis),内存型 2GB
简介: MVC、MVP 和 MVVM 是三种常见的软件架构模式,用于分离用户界面和业务逻辑。MVC(Model-View-Controller)通过模型、视图和控制器分离数据、界面和控制逻辑;MVP(Model-View-Presenter)将控制逻辑移到 Presenter 中,减少视图的负担;MVVM(Model-View-ViewModel)通过数据绑定机制进一步解耦视图和模型,提高代码的可维护性和测试性。

一、MVC模式(Model - View - Controller)

  1. 基本概念

    • Model(模型):代表应用程序的数据和业务逻辑。它负责管理数据的存储、检索和更新。例如,在一个电商应用中,Model可以包含商品信息(如名称、价格、库存等)的存储结构,以及对这些数据进行增删改查的操作方法。
    • View(视图):是用户界面的呈现部分,用于向用户展示数据。它从Model获取数据来进行展示,并且通常提供用户交互的接口。比如,在网页应用中,View可以是一个HTML页面,通过某种模板语言(如Jinja2)将Model中的数据渲染成用户可以看到的网页内容。
    • Controller(控制器):起到了连接Model和View的桥梁作用。它接收用户在View上的操作请求(如点击按钮、提交表单等),根据请求调用Model中的相应业务逻辑方法,然后更新View。例如,当用户在电商应用的商品列表页面点击“添加到购物车”按钮时,Controller会接收到这个请求,调用Model中的添加商品到购物车的方法,之后可能会更新购物车的显示视图。
  2. 工作流程

    • 用户在View层进行操作,如输入数据或点击按钮。
    • View将用户操作事件发送给Controller。
    • Controller根据事件类型调用Model中对应的业务逻辑方法,对数据进行处理。
    • Model执行完操作后,将数据状态的变化通知Controller。
    • Controller更新View,使其显示最新的数据状态。
  3. 优缺点

    • 优点
      • 职责分离清晰,便于团队分工开发。不同的开发人员可以专注于Model、View或者Controller的开发。
      • 可维护性和可扩展性较好。由于各部分职责明确,当需要修改某一部分功能时(如更新业务逻辑或者改变用户界面),对其他部分的影响相对较小。
    • 缺点
      • View和Controller之间的耦合度相对较高。如果View的变化比较频繁,可能需要对Controller进行较多的修改。
      • 对于复杂的用户界面,Controller可能会变得臃肿,因为它需要处理大量的用户操作和视图更新逻辑。

二、MVP模式(Model - View - Presenter)

  1. 基本概念

    • Model(模型):与MVC中的Model类似,负责数据存储和业务逻辑处理。
    • View(视图):主要负责显示数据,它定义了用户界面的外观和交互方式。但是在MVP中,View是比较“被动”的,它通常只提供用户交互接口,不包含业务逻辑。
    • Presenter(主持人):它是MVP模式的核心。Presenter从Model获取数据,然后将数据格式转换为View能够理解的形式,并将数据传递给View进行显示。同时,Presenter接收View的用户操作事件,调用Model中的业务逻辑方法来处理这些事件。例如,在一个天气应用中,Presenter会从Model(获取天气数据的接口)获取天气数据,然后将数据处理成适合View(如天气图标和温度数字的显示格式)展示的形式,当用户在View中刷新天气数据时,Presenter会调用Model中的数据更新方法。
  2. 工作流程

    • 用户在View上进行操作。
    • View将用户操作事件发送给Presenter。
    • Presenter调用Model中的业务逻辑方法来处理数据。
    • Model将数据返回给Presenter。
    • Presenter将数据处理后传递给View进行显示。
  3. 优缺点

    • 优点
      • 降低了View和Model之间的耦合度。View只与Presenter交互,不直接依赖Model,使得View的可替换性增强。
      • 方便进行单元测试。由于Presenter不涉及复杂的视图渲染逻辑,主要是数据处理和业务逻辑的调用,所以更容易进行单元测试。
    • 缺点
      • 因为引入了Presenter,代码结构相对复杂一些,开发成本可能会增加。
      • Presenter可能会变得过于复杂,承担了大量的数据转换和业务逻辑与视图交互的工作。

三、MVVM模式(Model - View - ViewModel)

  1. 基本概念

    • Model(模型):和前面两种模式类似,包含数据和业务逻辑。
    • View(视图):负责用户界面的展示,与用户进行交互。
    • ViewModel(视图模型):它是MVVM的关键部分。ViewModel对Model中的数据进行包装和转换,使其能够方便地被View绑定和使用。ViewModel还提供了一些命令(Commands),用于处理View中的用户操作。例如,在一个音乐播放应用中,ViewModel可以将音乐文件的相关数据(如歌曲名、歌手、时长等)进行包装,通过数据绑定的方式让View(如播放列表界面)能够直接显示这些数据。同时,ViewModel可以提供“播放”“暂停”等命令,当用户在View中点击播放或暂停按钮时,View通过绑定的方式调用ViewModel中的相应命令,ViewModel再去调用Model中的播放或暂停音乐的业务逻辑。
  2. 工作流程

    • Model的数据发生变化时,ViewModel会感知到这种变化并更新自己的数据状态。
    • View通过数据绑定机制自动获取ViewModel更新后的数据,从而更新自己的显示。
    • 用户在View上进行操作,View通过数据绑定调用ViewModel中的命令。
    • ViewModel根据命令调用Model中的业务逻辑方法来处理数据。
  3. 优缺点

    • 优点
      • 数据绑定机制使得View和ViewModel之间的交互更加简洁高效。开发人员不需要手动更新视图,当数据变化时,视图会自动更新。
      • 提高了代码的可维护性和可测试性。ViewModel的分离使得业务逻辑和视图逻辑更加清晰,方便分别进行维护和测试。
    • 缺点
      • 数据绑定的实现可能会比较复杂,不同的框架实现数据绑定的方式和性能也有所不同。
      • 对于简单的应用场景,使用MVVM可能会增加不必要的复杂性。
相关文章
|
17天前
|
存储 弹性计算 人工智能
阿里云Alex Chen:普惠计算服务,助力企业创新
本文整理自阿里云弹性计算产品线、存储产品线产品负责人陈起鲲(Alex Chen)在2024云栖大会「弹性计算专场-普惠计算服务,助力企业创新」中的分享。在演讲中,他分享了阿里云弹性计算,如何帮助千行百业的客户在多样化的业务环境和不同的计算能力需求下,实现了成本降低和效率提升的实际案例。同时,基于全面升级的CIPU2.0技术,弹性计算全线产品的性能、稳定性等关键指标得到了全面升级。此外,他还宣布了弹性计算包括:通用计算、加速计算和容器计算的全新产品家族,旨在加速AI与云计算的融合,推动客户的业务创新。
|
7天前
|
SQL 人工智能 安全
【灵码助力安全1】——利用通义灵码辅助快速代码审计的最佳实践
本文介绍了作者在数据安全比赛中遇到的一个开源框架的代码审计过程。作者使用了多种工具,特别是“通义灵码”,帮助发现了多个高危漏洞,包括路径遍历、文件上传、目录删除、SQL注入和XSS漏洞。文章详细描述了如何利用这些工具进行漏洞定位和验证,并分享了使用“通义灵码”的心得和体验。最后,作者总结了AI在代码审计中的优势和不足,并展望了未来的发展方向。
|
3天前
|
负载均衡 算法 网络安全
阿里云WoSign SSL证书申请指南_沃通SSL技术文档
阿里云平台WoSign品牌SSL证书是由阿里云合作伙伴沃通CA提供,上线阿里云平台以来,成为阿里云平台热销的国产品牌证书产品,用户在阿里云平台https://www.aliyun.com/product/cas 可直接下单购买WoSign SSL证书,快捷部署到阿里云产品中。
1843 6
阿里云WoSign SSL证书申请指南_沃通SSL技术文档
|
1天前
|
存储 安全 Oracle
【灵码助力安全3】——利用通义灵码辅助智能合约漏洞检测的尝试
本文探讨了智能合约的安全性问题,特别是重入攻击、预言机操纵、整数溢出和时间戳依赖性等常见漏洞。文章通过实例详细分析了重入攻击的原理和防范措施,展示了如何利用通义灵码辅助检测和修复这些漏洞。此外,文章还介绍了最新的研究成果,如GPTScan工具,该工具通过结合大模型和静态分析技术,提高了智能合约漏洞检测的准确性和效率。最后,文章总结了灵码在智能合约安全领域的应用前景,指出尽管存在一些局限性,但其在检测和预防逻辑漏洞方面仍展现出巨大潜力。
|
24天前
|
存储 人工智能 弹性计算
产品技术能力飞跃,阿里云E-HPC荣获“CCF 产品创新奖”!
9月24日,在中国计算机学会举办的“2024 CCF 全国高性能计算学术年会”中,阿里云弹性高性能计算(E-HPC)荣获「 CCF HPC China 2024 产品创新奖」。这也是继 2022 年之后,阿里云E-HPC 再次荣获此奖项,代表着阿里云在云超算领域的持续创新结果,其产品能力和技术成果得到了业界的一致认可。
|
6天前
|
Web App开发 算法 安全
什么是阿里云WoSign SSL证书?_沃通SSL技术文档
WoSign品牌SSL证书由阿里云平台SSL证书合作伙伴沃通CA提供,上线阿里云平台以来,成为阿里云平台热销的国产品牌证书产品。
1777 2
|
15天前
|
编解码 Java 程序员
写代码还有专业的编程显示器?
写代码已经十个年头了, 一直都是习惯直接用一台Mac电脑写代码 偶尔接一个显示器, 但是可能因为公司配的显示器不怎么样, 还要接转接头 搞得桌面杂乱无章,分辨率也低,感觉屏幕还是Mac自带的看着舒服
|
22天前
|
存储 人工智能 缓存
AI助理直击要害,从繁复中提炼精华——使用CDN加速访问OSS存储的图片
本案例介绍如何利用AI助理快速实现OSS存储的图片接入CDN,以加速图片访问。通过AI助理提炼关键操作步骤,避免在复杂文档中寻找解决方案。主要步骤包括开通CDN、添加加速域名、配置CNAME等。实测显示,接入CDN后图片加载时间显著缩短,验证了加速效果。此方法大幅提高了操作效率,降低了学习成本。
5024 15
|
9天前
|
人工智能 关系型数据库 Serverless
1024,致开发者们——希望和你一起用技术人独有的方式,庆祝你的主场
阿里云开发者社区推出“1024·云上见”程序员节专题活动,包括云上实操、开发者测评和征文三个分会场,提供14个实操活动、3个解决方案、3 个产品方案的测评及征文比赛,旨在帮助开发者提升技能、分享经验,共筑技术梦想。
1015 147
|
17天前
|
存储 缓存 关系型数据库
MySQL事务日志-Redo Log工作原理分析
事务的隔离性和原子性分别通过锁和事务日志实现,而持久性则依赖于事务日志中的`Redo Log`。在MySQL中,`Redo Log`确保已提交事务的数据能持久保存,即使系统崩溃也能通过重做日志恢复数据。其工作原理是记录数据在内存中的更改,待事务提交时写入磁盘。此外,`Redo Log`采用简单的物理日志格式和高效的顺序IO,确保快速提交。通过不同的落盘策略,可在性能和安全性之间做出权衡。
1582 12