MVVM、MVC的区别、什么是MVVM
一、什么是MVVM
(一)定义
MVVM是Model - View - ViewModel的缩写,它是一种软件架构设计模式,主要用于构建用户界面。这种模式将应用程序分为三个主要部分:
- Model(模型层)
- 它是应用程序中负责数据管理和业务逻辑的部分。例如,在一个电商应用中,Model层可能包含商品信息(如价格、库存等)、用户信息(如用户名、密码等)以及与数据库交互的代码。Model层不直接与用户界面交互,它只关注数据的存储、获取和处理。比如,当商品价格需要根据促销活动进行调整时,Model层会负责计算新的价格,并将新的数据提供给其他部分。
- View(视图层)
- 这是用户直接看到和交互的部分,也就是用户界面。它可以是网页、移动应用的界面等。View层的主要职责是展示数据和接收用户的输入。例如,在一个新闻阅读应用的View层,会显示新闻的标题、内容、图片等信息,并且有按钮让用户可以点赞、评论等。View层不直接处理数据逻辑,它只是将用户的操作(如点击按钮)通知给ViewModel层。
- ViewModel(视图模型层)
- 它是连接View和Model的桥梁。ViewModel层的作用是将Model层的数据转换成View层可以显示的格式,并且将View层的用户操作转化为Model层可以理解的指令。例如,当用户在新闻阅读应用中点击“点赞”按钮时,ViewModel层会接收到这个操作,然后通知Model层去更新点赞数量。同时,当Model层的数据发生变化(如新闻内容更新)时,ViewModel层会将这些数据更新传递给View层,从而更新用户界面。
(二)工作原理
- 数据绑定
- 这是MVVM模式的核心机制之一。在MVVM框架下,View层和ViewModel层之间通过数据绑定进行通信。数据绑定可以是单向的也可以是双向的。单向数据绑定通常是ViewModel到View,例如,ViewModel层从Model层获取新闻标题数据,然后通过数据绑定机制将新闻标题显示在View层的新闻标题区域。双向数据绑定则允许View层和ViewModel层的数据相互更新。例如,在一个表单应用中,用户在输入框(View层)输入内容时,ViewModel层的数据会实时更新,反之亦然。
- 命令绑定
- 用于将用户的操作(如点击按钮)从View层传递到ViewModel层。例如,在一个购物应用中,用户点击“加入购物车”按钮,这个操作会通过命令绑定传递给ViewModel层,ViewModel层再根据业务逻辑(如检查库存等)处理这个操作,并且可能会通知Model层进行数据更新(如增加购物车中的商品数量)。
二、MVVM和MVC的区别
(一)架构组成
- MVC(Model - View - Controller)
- MVC也是将应用程序分为三个部分:Model、View和Controller。
- Model:和MVVM中的Model类似,负责数据和业务逻辑。
- View:也是用户界面部分,用于展示数据和接收用户输入。
- Controller(控制器层):在MVC中,Controller是核心部分,它接收用户从View层传来的请求,然后根据请求去操作Model层,并且将处理结果返回给View层。例如,在一个在线课程平台,当用户点击“报名课程”按钮时,Controller会接收这个请求,然后去检查Model层中的课程信息(如是否还有名额等),如果可以报名,就更新Model层的数据(如增加报名人数),最后将报名成功的信息返回给View层显示给用户。
- MVC也是将应用程序分为三个部分:Model、View和Controller。
- MVVM
- 如前面所述,MVVM有Model、View和ViewModel三个部分。ViewModel在MVVM中起到了类似MVC中Controller的作用,但又有所不同。ViewModel更专注于数据绑定和视图逻辑的处理,而不是像Controller那样直接处理用户的请求。
(二)数据流
- MVC
- 数据流是线性的。用户在View层发起操作,请求传递给Controller,Controller处理后更新Model或者将结果返回给View。例如,用户在博客应用中点击“发布文章”按钮,View层将请求发送给Controller,Controller获取文章内容等数据,然后更新Model层(如将文章存储到数据库),最后将发布成功的信息通过View层展示给用户。
- MVVM
- 数据流主要是通过数据绑定来实现的。View层和ViewModel层之间通过数据绑定双向通信,ViewModel层和Model层之间也有数据交互。例如,在一个天气应用中,Model层从天气服务获取天气数据,然后通过ViewModel层的数据绑定机制,将天气信息(如温度、天气状况等)显示在View层。当用户切换城市时,View层通知ViewModel层,ViewModel层再通知Model层获取新城市的天气数据,然后更新View层。
(三)开发效率和复杂度
- MVC
- MVC模式在一些简单的应用程序中比较容易理解和实现。例如,对于一个小型的博客网站,通过MVC模式可以快速搭建起基本的发布文章、浏览文章等功能。但是随着应用程序的复杂度增加,Controller可能会变得臃肿。因为Controller需要处理大量的用户请求和业务逻辑,当功能越来越多时,Controller代码可能会变得难以维护。
- MVVM
- MVVM模式在数据绑定和视图逻辑处理方面有优势,特别是在复杂的用户界面应用中。例如,在一个具有复杂表单和动态数据更新的企业管理软件中,MVVM模式可以通过数据绑定减少大量的模板代码,使得开发者可以更专注于业务逻辑的实现。不过,MVVM的学习曲线相对较高,需要开发者理解数据绑定、命令绑定等概念,并且在一些简单的应用中可能会显得过于复杂。
相关文章:
MVVM、MVC的区别、什么是MVVM
一、什么是MVVM (一)定义 MVVM是Model - View - ViewModel的缩写,它是一种软件架构设计模式,主要用于构建用户界面。这种模式将应用程序分为三个主要部分: Model(模型层) 它是应用程序中负责…...

网页自动化部署(webhook方法)
实现步骤: 宝塔安装宝塔WebHook 2.5插件。 github 上配置网页仓库(或可在服务器的网页根目录clone)。 配置宝塔WebHook 2.5 添加hook脚本; 编辑添加syncJC脚本; #!/bin/bash # 定义网站根目录 WEBROOT"/www…...
线性代数入门:轻松理解二阶与三阶行列式的定义与理解
前言 行列式是线性代数中一个非常基础但又极其重要的概念。它不仅是解线性方程组的利器,还在矩阵理论、向量空间、特征值等问题中扮演着关键角色。今天,我将用最通俗易懂的方式,向高中生朋友们介绍二阶和三阶行列式的基本概念和计算方法。让…...

AU6825集成音频DSP的2x32W数字型ClaSSD音频功率放大器(替代TAS5825)
1.特性 ● 输出配置 - 立体声 2.0: 2 x 32W (8Ω,24V,THD N 10%) - 立体声 2.0: 2 x 26W (8Ω,21V,THD N 1%) ● 供电电压范围 - PVDD:4.5V -26.4V - DVDD: 1.8V 或者 3.3V ● 静态功耗 - 37mA at PVDD12V ● 音频性能指标 - THDN ≤ 0.02% at 1W,1kHz - SNR ≥ 107dB (A-wei…...

华为云Flexus+DeepSeek征文|DeepSeek-V3/R1商用服务体验全流程
华为云 Flexus 与 DeepSeek-V3/R1 的深度整合,构建了一套 “弹性算力 智能引擎” 的协同体系。 Flexus 系列云服务器基于柔性计算技术,通过动态资源调度(如 Flexus X 实例)实现 CPU / 内存的实时弹性分配,尤其适合大模…...
Go语言的原子操作
当我们想要对某个变量并发安全的修改,除了使用官方提供的mutex,还可以使用sync/atomic包的原子操作,它能够保证对变量的读取或修改期间不被其他的协程所影响。 Golang提供的原子操作都是非侵入式的,由标准库sync/atmoic包提供&am…...
Visual Studio 2022 插件推荐
Visual Studio 2022 插件推荐 Visual Studio 2022 (简称 VS2022) 是一款强大的 IDE,适合各类系统组件、框架和应用的开发。插件是接入 VS2022 最重要的扩展方式之一,它们可以大幅提升开发效率、优化代码质量,并提供强大的调试和分析功能。 …...
【深度学习-pytorch篇】3. 优化器实现:momentum,NAG,AdaGrad,RMSProp,Adam
Optimization Algorithms Explained 1. Beale Function 与导数函数讲解 Beale 函数是一个著名的用于测试优化算法性能的函数,其具有多个局部极值点,适合评估不同优化器的表现: def beale(x1, x2):"""Beale 函数定义&#x…...

C# NX二次开发-查找连续倒圆角面
在QQ群里有人问怎么通过一个选择一个倒圆角面来自动选中一组倒圆角面。 可以通过ufun函数 UF_MODL_ask_face_type 和 UF_MODL_ask_face_props 可判断处理选择相应的一组圆角面。 代码: Tag[] 查找连续倒圆角面(Tag faceTag) {theUf.Modl.AskFaceType(faceTag, out int typ…...

今天遇到的bug
先呈现一下BUG现象。 这主要是一个传参问题,参数一直传不过去。后来我才发现,问题所在。 我们这里用的RquestBody接收参数,所有请求的参数需要用在body体中接收,但是我们用postman,用的是字符串查询方式传参&#x…...
Go语言字符串类型详解
1. 定义字符串类型 package mainimport ("fmt");func main() {var str1 string "你好 GoLang 1"var str2 "你好 GoLang 2"str3 : "你好 GoLang 3"fmt.Printf("%v--%T\n", str1, str1)// 你好 GoLang 1--stringfmt.Printf…...

长安链智能合约命令解析(全集)
创建命令解析 ./cmc client contract user create \ --contract-namefact \ --runtime-typeWASMER \ --byte-code-path./testdata/claim-wasm-demo/rust-fact-2.0.0.wasm \ --version1.0 \ --sdk-conf-path./testdata/sdk_config.yml \ --admin-key-file-paths./testdata/cryp…...

一、OpenCV的基本操作
目录 1、OpenCV的模块 2、OpenCV的基础操作 2.1图像的IO操作 2.2绘制几何图形 2.3获取并修改图像中的像素点 2.4 获取图像的属性 2.5图像通道的拆分与合并 2.6色彩空间的改变 3、OpenCV的算数操作 3.1图像的加法 3.2图像的混合 3.3总结 1、OpenCV的模块 2、OpenCV的基…...

裂缝仪在线监测装置:工程安全领域的“实时守卫者”
在基础设施运维领域,裂缝扩展是威胁建筑结构安全的核心隐患之一。传统人工巡检方式存在效率低、时效性差、数据主观性强等局限,而裂缝仪在线监测装置通过技术迭代,实现了对结构裂缝的自动化、持续性追踪,为工程安全评估提供科学依…...

【论文精读】2024 ECCV--MGLD-VSR现实世界视频超分辨率(RealWorld VSR)
文章目录 一、摘要二、问题三、Method3.1 Latent Diffusion Model3.2 Motion-guided Diffusion Sampling3.3 Temporal-aware Decoder Fine-tuning 四、实验设置4.1 训练阶段4.2 训练数据 贡献总结 论文全称: Motion-Guided Latent Diffusion for Temporally Consis…...

SpringBoot简单体验
1 Helloworld 打开:https://start.spring.io/ 选择maven配置。增加SpringWeb的依赖。 Generate之后解压,代码大致如下: hpDESKTOP-430500P:~/springboot2/demo$ tree ├── HELP.md ├── mvnw ├── mvnw.cmd ├── pom.xml └── s…...
【系统架构设计师】2025年上半年真题论文回忆版: 论系统负载均衡设计方法(包括解题思路和参考素材)
更多内容请见: 备考系统架构设计师-专栏介绍和目录 文章目录 真题题目(2025年上半年 试题3)解题思路论文素材参考1、静态负载均衡策略2、动态负载均衡策略3、基于场景的负载均衡真题题目(2025年上半年 试题3) 请围绕 “论系统负载均衡设计方法” 论题,依次从以下三个方面…...

2025年通用 Linux 服务器操作系统该如何选择?
2025年通用 Linux 服务器操作系统该如何选择? 服务器操作系统的选择对一个企业IT和云服务影响很大,主推的操作系统在后期更换的成本很高,而且也有很大的迁移风险,所以企业在选择服务器操作系统时要尤为重视。 之前最流行的服务器…...

Azure devops 系统之五-部署ASP.NET web app
今天介绍如何通过vscode 来创建一个asp.net web app,并部署到azure 上。 创建 ASP.NET Web 应用 在您的计算机上打开一个终端窗口并进入工作目录。使用 dotnet new webapp 命令创建一个新的 .NET Web 应用,然后将目录切换到新创建的应用。 dotnet new webapp -n MyFirstAzu…...
Hadoop是什么
注:本人不懂Hadoop是什么,问的大模型,让它用生动浅显的语言向我解释。为了防止忘记,我把它说的记录下来。接下来的解释都是大模型生成的,如果有错误的地方欢迎指正 。 Hadoop 是什么?(一句…...

学习路之PHP--easyswoole_panel安装使用
学习路之PHP--easyswoole_panel安装使用 一、新建文件夹二、安装三、改配置地址四、访问 IP:Port 自动进入index.html页面 一、新建文件夹 /www/wwwroot/easyswoole_panel 及配置ftp 解压easyswoole_panel源码 https://github.com/easyswoole-panel/easyswoole_panel 二、安…...
结合 AI 编程,让前端开发更简单:趋势、方法与实践
在 AI 迅猛发展的浪潮中,前端开发正在迎来范式转变。本文将深入探讨如何将 AI 编程能力嵌入前端工程体系中,重塑前端生产力工具链与开发方式。 一、前端开发的核心痛点 尽管前端框架(如 Vue、React)已经大大简化了 UI 构建&#…...

【拓扑排序】P6560 [SBCOI2020] 时光的流逝|普及+
本文涉及知识点 C图论 拓扑排序 P6560 [SBCOI2020] 时光的流逝 题目背景 时间一分一秒的过着,伴随着雪一同消融在了这个冬天, 或许,要是时光能停留在这一刻,该有多好啊。 … “这是…我在这个小镇的最后一个冬天了吧。” “嗯…...

SSRF 接收器
接收请求 IP.php <?php // 定义日志文件路径 $logFile hackip.txt;// 处理删除请求 if (isset($_POST[delete])) {$ipToDelete $_POST[ip];$lines file($logFile, FILE_IGNORE_NEW_LINES);$newLines array();foreach ($lines as $line) {$parts explode( | , $line);…...
【设计模式】责任链
【设计模式】责任链 在实际开发中,我们经常遇到这样的需求:某个请求需要经过多个处理者,但处理的顺序、方式可能会变化或扩展。这时候,责任链模式就能派上用场。 责任链模式(Chain of Responsibility) 是…...
unix/linux source 命令,其高级使用
就像在物理学中,掌握了基本定律后,我们可以开始研究更复杂的系统和现象,source 的高级用法也是建立在对其基本行为深刻理解之上的。 让我们一起探索 source 的高级应用领域: 1. 条件化加载 (Conditional Sourcing) 根据某些条件来决定是否 source 一个文件,或者 source…...
邮件验证码存储推荐方式
邮件验证码的存储方案需要兼顾 安全性、性能 和 可维护性,以下是详细分析和推荐方案: 1. 推荐方案:Redis(首选) 为什么选择 Redis? 优势说明高性能内存读写,毫秒级响应,适合高频验…...
Allegro 输出生产数据详解
说明 用于PCB裸板的生产可以分别单独创建文件 光绘数据(Gerber)、钻孔(NC Drill)、IPC网表;或者通过ODB++或IPC2581文件(这是一个新格式),它包含生产裸板所需要的所有信息 光绘数据 Artwork Gerber 光绘数据一般包含设计中各个层面的蚀刻线路、阻焊、铅锡、字符等信…...

FastAPI MCP 快速入门教程
目录 什么是 FastAPI MCP?项目设置1. 初始化项目2. 安装依赖3. 项目结构 编写代码创建主应用文件 运行和测试1. 启动服务器2. 使用 MCP Inspector 测试 什么是 FastAPI MCP? FastAPI MCP 是一个将 FastAPI 应用程序转换为 Model Context Protocol (MCP)…...

uni-app学习笔记二十一--pages.json中tabBar设置底部菜单项和图标
如果应用是一个多 tab 应用,可以通过 tabBar 配置项指定一级导航栏,以及 tab 切换时显示的对应页。 在 pages.json 中提供 tabBar 配置,不仅仅是为了方便快速开发导航,更重要的是在App和小程序端提升性能。在这两个平台ÿ…...