【MVP 和 MVVM 相比 MVC 有哪些优化点?】
MVP 和 MVVM 相比 MVC 的优化及原因
1. MVC 的痛点
在传统 MVC 模式中:
- 视图(View)和模型(Model)直接交互:View 可能直接监听 Model 的变化(如观察者模式),导致耦合。
- 控制器(Controller)职责过重:需要处理用户输入、更新 Model、协调 View,代码臃肿。
- 可测试性差:View 和 Controller 紧密绑定,难以单独测试业务逻辑。
2. MVP 的优化
优化点:
- 职责分离更彻底:
- Presenter 替代 Controller,接管所有业务逻辑和用户交互。
- View 完全被动:仅负责 UI 渲染,不处理逻辑。
- 解耦 View 和 Model:
- View 通过接口与 Presenter 通信,避免直接依赖 Model。
- 提升可测试性:
- Presenter 不依赖具体 View 实现,可用 Mock View 进行单元测试。
为什么这样优化?
- 解决 MVC 中 View 和 Model 直接交互的问题,减少耦合。
- 将复杂逻辑从 View 抽离到 Presenter,符合单一职责原则。
适用场景:
- Android 传统开发(Activity 作为 View)。
- 需要高可测试性的桌面应用(如 .NET WinForms)。
3. MVVM 的优化
优化点:
- 双向数据绑定:
- View 自动响应 ViewModel 的数据变化(如 Vue/React 的响应式更新)。
- 无需手动操作 DOM 或 UI 组件(如
setText())。
- ViewModel 取代 Presenter:
- 封装 View 的显示逻辑和状态,不直接持有 View 引用。
- 进一步解耦:
- View 仅通过绑定声明依赖 ViewModel,Model 独立于 UI。
为什么这样优化?
- 减少模板代码(如手动更新 UI),提升开发效率。
- 适应现代前端复杂的数据驱动 UI 需求。
适用场景:
- 现代前端框架(Vue、React、Angular)。
- 数据密集型应用(如实时仪表盘、表单交互)。
4. MVP 和 MVVM 的核心区别
| 维度 | MVP | MVVM |
|---|---|---|
| 数据流 | 单向(View ↔ Presenter → Model) | 双向(View ↔ ViewModel ↔ Model) |
| 核心机制 | 接口通信 | 数据绑定 |
| 测试重点 | Presenter 逻辑 | ViewModel 数据状态 |
| 典型框架 | Android (传统)、.NET WinForms | Vue、React、WPF |
5. 总结:优化背后的设计思想
| 模式 | 核心优化思想 | 技术手段 |
|---|---|---|
| MVP | 解耦 View 和 Model | 接口隔离 + Presenter 中间层 |
| MVVM | 数据驱动 UI | 响应式编程 + 双向数据绑定 |
- 为什么需要这些优化?
- 降低维护成本:清晰的职责划分让代码更易修改和扩展。
- 提升开发效率:减少手动同步 UI 和数据的重复劳动。
- 增强可测试性:业务逻辑与 UI 分离,便于单元测试。
实际案例对比
-
MVC(传统 Web)
// Spring MVC Controller @Controller public class UserController {@Autowiredprivate UserService userService; // Model@GetMapping("/users")public String getUsers(Model model) {model.addAttribute("users", userService.getAllUsers()); // 数据传递到 Viewreturn "user-list"; // View 模板渲染} }- 痛点:View(JSP/Thymeleaf)依赖 Model 数据,逻辑分散在 Controller。
-
MVP(Android)
// Presenter class UserPresenter(private val view: UserView) {fun loadUsers() {val users = userRepository.getUsers() // Modelview.showUsers(users) // 通过接口更新 View} }// View 接口 interface UserView {fun showUsers(users: List<User>) }- 优化:View(Activity)被动实现接口,Presenter 独立测试。
-
MVVM(Vue.js)
<template><div>{{ message }}</div> <!-- View --> </template><script> export default {data() {return { message: "Hello" } // ViewModel} } </script>- 优化:数据变更自动触发 UI 更新,无需手动操作 DOM。
如何选择架构?
- 简单项目 → MVC(快速上手,逻辑集中)。
- 高测试需求 → MVP(接口隔离,Mock 测试方便)。
- 复杂数据流 → MVVM(响应式更新,减少样板代码)。
这些优化本质上是对 MVC 职责划分的细化,通过引入中间层(Presenter/ViewModel)和现代编程范式(数据绑定),解决传统 MVC 在复杂场景下的不足。
相关文章:
【MVP 和 MVVM 相比 MVC 有哪些优化点?】
MVP 和 MVVM 相比 MVC 的优化及原因 1. MVC 的痛点 在传统 MVC 模式中: 视图(View)和模型(Model)直接交互:View 可能直接监听 Model 的变化(如观察者模式),导致耦合。…...
ttkbootstrap 实现日期选择器, 开始和结束时间
ttkbootstrap 实现日期选择器, 开始和结束时间 1. 展示 2. 打印 3. 源码 from datetime import datetime import ttkbootstrap as ttkclass DateTimeEntryStart(ttk.Frame):def __init__(self, masterNone, **kwargs):super().__init__(master, **kwargs)self.dat…...
Vulnhub-PrinkysPalacev3
Vulnhub-PrinkysPalacev3 1、主机发现 arp-scan -l 扫描同网段 2、端口扫描 nmap -sS -sV 192.168.66.185 nmap -sS -A -T4 -p- 192.168.66.185 nmap --scriptvuln 192.168.66.185 PORT STATE SERVICE VERSION 21/tcp open ftp vsftpd 2.0.8 or later 5555/tcp o…...
matlab从pytorch中导入LeNet-5网络框架
文章目录 一、Pytorch的LeNet-5网络准备二、保存用于导入matlab的model三、导入matlab四、用matlab训练这个导入的网络 这里演示从pytorch的LeNet-5网络导入到matlab中进行训练用。 一、Pytorch的LeNet-5网络准备 根据LeNet-5的结构图,我们可以写如下结构 import…...
淘宝商品数据爬取与分析
淘宝商品数据爬取与分析是一个涉及网络爬虫技术和数据分析方法的过程,以下是其主要步骤: 数据爬取 确定爬取目标:明确要爬取的淘宝商品类别、具体商品名称或关键词等,例如想要分析智能手机市场,就以 “智能手机” 为…...
Spring Boot向Vue发送消息通过WebSocket实现通信
注意:如果后端有contextPath,如/app,那么前端访问的url就是ip:port/app/ws 后端实现步骤 添加Spring Boot WebSocket依赖配置WebSocket端点和消息代理创建控制器,使用SimpMessagingTemplate发送消息 前端实现步骤 安装sockjs-…...
Django4.0的快速查询以及分页
1. filter 方法 filter 是 Django ORM 中最常用的查询方法之一。它用来根据给定的条件过滤查询集并返回满足条件的对象。 articles Article.objects.all() # 使用 SearchFilter 进行搜索 search_param request.query_params.get(search, None) author_id request.query_pa…...
LangChain/Eliza框架在使用场景上的异同,Eliza通过配置实现功能扩展的例子
LangChain与Eliza框架的异同分析 一、相同点 模块化架构设计 两者均采用模块化设计,支持灵活扩展和功能组合。LangChain通过Chains、Agents等组件实现多步骤任务编排,Eliza通过插件系统和信任引擎实现智能体功能的动态扩展。模块化特性降低…...
用spring-webmvc包实现AI(Deepseek)事件流(SSE)推送
前后端: Spring Boot Angular spring-webmvc-5.2.2包 代码片段如下: 控制层: GetMapping(value "/realtime/page/ai/sse", produces MediaType.TEXT_EVENT_STREAM_VALUE)ApiOperation(value "获取告警记录进行AI分析…...
MusicMint ,AI音乐生成工具
MusicMint是什么 MusicMint 是一款强大的人工智能音乐创作工具,旨在帮助用户轻松制作个性化的音乐作品。借助先进的 AI 技术,用户只需输入简短的描述或选择心仪的音乐风格,便能迅速生成独特的歌曲。该平台支持多种音乐风格,包括流…...
嵌入式学习笔记——SPI协议
SPI协议详解 SPI协议概述SPI接口信号介绍SPI通信模式SPI的通信流程SPI的优缺点优点缺点 SPI在STM32上的实现SPI引脚配置SPI初始化代码(STM32F10x)SPI主设备发送和接收数据SPI从设备数据处理 总结 SPI协议概述 SPI(Serial Peripheral Interfa…...
网络编程—Socket套接字(UDP)
上篇文章: 网络编程—网络概念https://blog.csdn.net/sniper_fandc/article/details/146923380?fromshareblogdetail&sharetypeblogdetail&sharerId146923380&sharereferPC&sharesourcesniper_fandc&sharefromfrom_link 目录 1 概念 2 Soc…...
视频设备轨迹回放平台EasyCVR综合智能化,搭建运动场体育赛事直播方案
一、背景 随着5G技术的发展,体育赛事直播迎来了新的高峰。无论是NBA、西甲、英超、德甲、意甲、中超还是CBA等热门赛事,都是值得记录和回放的精彩瞬间。对于体育迷来说,选择观看的平台众多,但是作为运营者,搭建一套体…...
AIGC实战——CycleGAN详解与实现
AIGC实战——CycleGAN详解与实现 0. 前言1. CycleGAN 基本原理2. CycleGAN 模型分析3. 实现 CycleGAN小结系列链接 0. 前言 CycleGAN 是一种用于图像转换的生成对抗网络(Generative Adversarial Network, GAN),可以在不需要配对数据的情况下将一种风格的图像转换成…...
VS2022远程调试Linux程序
一、 1、VS2022安装参考 VS Studio2022安装教程(保姆级教程)_visual studio 2022-CSDN博客 注意:勾选的时候,要勾选下方的选项,才能调试Linux环境下运行的程序! 2、VS2022远程调试Linux程序测试 原文参…...
345-java人事档案管理系统的设计与实现
345-java人事档案管理系统的设计与实现 项目概述 本项目为基于Java语言的人事档案管理系统,旨在帮助企事业单位高效管理员工档案信息,实现档案的电子化、自动化管理。系统涵盖了员工信息的录入、查询、修改、删除等功能,同时具备权限控制和…...
【Linux系统编程】进程概念,进程状态
目录 一,操作系统(Operator System) 1-1概念 1-2设计操作系统的目的 1-3核心功能 1-4系统调用和库函数概念 二,进程(Process) 2-1进程概念与基本操作 2-2task_struct结构体内容 2-3查看进程 2-4通…...
优选算法的妙思之流:分治——快排专题
专栏:算法的魔法世界 个人主页:手握风云 目录 一、快速排序 二、例题讲解 2.1. 颜色分类 2.2. 排序数组 2.3. 数组中的第K个最大元素 2.4. 库存管理 III 一、快速排序 分治,简单理解为“分而治之”,将一个大问题划分为若干个…...
# 实时人脸识别系统:基于 OpenCV 和 Python 的实现
实时人脸识别系统:基于 OpenCV 和 Python 的实现 在当今数字化时代,人脸识别技术已经广泛应用于各种场景,从手机解锁到安防监控,再到智能门禁系统。今天,我将通过一个完整的代码示例,详细讲解如何使用 Pyt…...
Mysql 中 ACID 背后的原理
在 MySQL 中,ACID 是事务处理的核心原则,用于保证数据库在执行事务时的可靠性、数据一致性和稳定性。ACID 是四个关键特性的首字母缩写,分别是:Atomicity(原子性)、Consistency(一致性ÿ…...
wx206基于ssm+vue+uniapp的优购电商小程序
开发语言:Java框架:ssmuniappJDK版本:JDK1.8服务器:tomcat7数据库:mysql 5.7(一定要5.7版本)数据库工具:Navicat11开发软件:eclipse/myeclipse/ideaMaven包:M…...
React编程高级主题:错误处理(Error Handling)
文章目录 **5.2 错误处理(Error Handling)概述****5.2.1 onErrorReturn / onErrorResume(错误回退)****1. onErrorReturn:提供默认值****2. onErrorResume:切换备用数据流** **5.2.2 retry / retryWhen&…...
ubuntu20.04升级成ubuntu22.04
命令行 sudo do-release-upgrade 我是按提示输入y确认操作,也可以遇到配置文件冲突时建议选择N保留当前配置...
SpringCloud(25)——Stream介绍
1.场景描述 当我们的分布式系统建设到一定程度了,或者服务间是通过异步请求来通讯的,那么我们避免不了使用MQ来解决问题。 假如公司内部进行了业务合并或者整合,需要服务A和服务B通过MQ的方式进行消息传递,而服务A用的是RabbitMQ&…...
OrangePi5Plus开发板不能正确识别USB 3.0 设备 (绿联HUB和Camera)
1、先插好上电(可正确识别) 2、上电开机后插入USB 3.0 设备,报错如下,只能检测到USB2.0--480M,识别不到USB3.0-5Gbps,重新插拔也不行 Apr 4 21:30:00 orangepi5plus kernel: [ 423.575966] usb 5-1: re…...
centos8上实现lvs集群负载均衡dr模式
1.前言 个人备忘笔记,欢迎探讨。 centos8上实现lvs集群负载均衡nat模式 centos8上实现lvs集群负载均衡dr模式 之前写过一篇lvs-nat模式。实验起来相对顺利。dr模式最大特点是响应报文不经调度器,而是直接返回客户机。 dr模式分同网段和不同网段。同…...
uniapp如何接入星火大模型
写在前面:最近的ai是真的火啊,琢磨了一下,弄个uniappx的版本开发个东西玩一下,想了想不知道放啥内容,突然觉得deepseek可以接入,好家伙,一对接以后发现这是个付费的玩意,我穷&#x…...
三、FFmpeg学习笔记
FFmpeg是一个开源、跨平台的多媒体处理框架,能够实现音视频的录制、转换、剪辑、编码、解码、流媒体传输、过滤与后期处理等几乎所有常见的多媒体操作。其强大之处在于几乎支持所有的音视频格式、编解码器和封装格式,是业界公认的“瑞士军刀”。 FFmp…...
Linux常用基础命令应用
目录 一、文件与目录操作(12个核心命令) 1. pwd - 显示当前路径 2. ls - 查看目录内容 3. cd - 切换目录 4. mkdir - 创建目录 5. touch - 创建文件 6. cp - 复制文件/目录 7. mv - 移动…...
【python中级】关于Cython 的源代码pyx的说明
【python中级】关于Cython 的源代码pyx的说明 1.背景2.编译3.语法1.背景 Cython 是一个编程语言和工具链,用于将 Python 代码(或类 Python 的代码)编译成 C 语言,再进一步生成高性能的 Python 扩展模块(.so 或 .pyd 文件)。 在 Python 中,.pyx 文件是 Cython 的源代码文…...
