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

MVC模式和MVVM模式

目录

一、MVC模式和MVVM模式

1. MVC模式

2. MVVM 模式

3.在Qt中的应用示例

4.总结

二、MVC与MVVM模式的共同点和区别

1.共同点

2.区别

3.交互流程

4.总结


MVC(Model-View-Controller)和MVVM(Model-View-ViewModel)是两种常见的软件设计模式,主要用于将用户界面(UI)与业务逻辑和数据分离,以提高代码的可维护性和可扩展性。

一、MVC模式和MVVM模式

1. MVC模式

核心思想:将应用程序分为三个核心组件,职责分离。

  • Model:管理数据和业务逻辑(如数据库操作、数据计算)。

  • View:负责界面显示,不处理业务逻辑。

  • Controller:接收用户输入(如按钮点击),协调 Model 和 View 的交互。

工作流程

  1. 用户通过 View 触发事件(如点击按钮)。

  2. Controller 接收事件,调用 Model 修改数据。

  3. Model 更新数据后,通知 View 刷新界面(通过观察者模式或直接调用)。

  • 优点:职责清晰,适合复杂交互的应用。
  • 缺点:View 和 Controller 可能耦合较紧,难以独立测试。

2. MVVM 模式

核心思想:通过数据绑定实现 View 和 Model 的自动同步。

  • Model:同 MVC,管理数据。

  • View:负责界面显示,声明式定义 UI(如 QML)。

  • ViewModel:暴露数据属性和命令,作为 View 和 Model 的桥梁,处理业务逻辑。

工作流程

  1. View 通过数据绑定(如 QML 的 property binding)直接关联 ViewModel 的属性。

  2. 用户操作 View(如输入文本)自动更新 ViewModel。

  3. ViewModel 修改 Model,Model 变化后通过通知机制(如信号)更新 ViewModel,再同步到 View。

  • 优点:View 和 ViewModel 解耦,适合数据驱动型 UI。
  • 缺点:数据绑定可能增加调试复杂度。

3.在Qt中的应用示例

示例1:Qt 中的MVC(使用QWidgets)

  • 场景:文件浏览器(显示文件夹结构)。

  • 代码结构

    // Model: QFileSystemModel 提供文件系统数据
    QFileSystemModel *model = new QFileSystemModel;
    model->setRootPath(QDir::homePath());
    
    // View: QTreeView 和 QListView 显示数据
    QTreeView *treeView = new QTreeView;
    treeView->setModel(model);
    QListView *listView = new QListView;
    listView->setModel(model);
    
    // Controller: 自定义逻辑(例如双击文件打开)
    QObject::connect(treeView, &QTreeView::doubleClicked, [](const QModelIndex &index) {
        QString path = model->filePath(index);
        QDesktopServices::openUrl(QUrl::fromLocalFile(path));
    });
  • 说明

    • Qt 的 Model/View 框架已内置 MVC 支持,但 Controller 通常由 View 的事件处理(如信号槽)实现。


示例2:Qt中的MVVM(使用QML + C++)

  • 场景:用户信息表单(输入姓名,实时显示欢迎语)。

  • 代码结构

    // View: main.qml
    TextField {
        text: viewModel.userName  // 绑定 ViewModel 属性
        onTextChanged: viewModel.setUserName(text)
    }
    Text {
        text: "Hello, " + viewModel.userName  // 自动更新
    }
    // ViewModel: UserViewModel 类(继承 QObject)
    class UserViewModel : public QObject {
        Q_OBJECT
        Q_PROPERTY(QString userName READ userName WRITE setUserName NOTIFY userNameChanged)
    public:
        QString userName() const { return m_name; }
        void setUserName(const QString &name) {
            if (m_name != name) {
                m_name = name;
                emit userNameChanged();
                // 可选:更新 Model(如保存到数据库)
            }
        }
    signals:
        void userNameChanged();
    private:
        QString m_name;
    };
    
    // 在 C++ 中暴露 ViewModel 到 QML
    UserViewModel viewModel;
    QQmlApplicationEngine engine;
    engine.rootContext()->setContextProperty("viewModel", &viewModel);
  • 说明

    • QML 的 property binding 实现自动同步,ViewModel 通过 Q_PROPERTY 暴露数据。


4.总结

  • MVC:适合传统 QWidgets 应用,需手动连接信号槽(Controller 逻辑分散)。

  • MVVM:适合 QML 应用,利用数据绑定简化代码,ViewModel 集中管理状态。

  • Qt 特点

    • Qt 的 Model/View 框架(如 QTableView + QSqlTableModel)是 MVC 的简化版。

    • MVVM 在 QML 中更自然,因为数据绑定是 QML 的核心特性。


  

二、MVC与MVVM模式的共同点和区别

1.共同点

  1. 关注点分离
  • 均将应用程序分为数据层(Model)、界面层(View)和逻辑层(Controller 或 ViewModel),实现职责解耦。
  1. 数据与界面分离
  • Model 独立管理数据逻辑,不依赖具体界面实现。
  1. 用户输入处理
  • 均需处理用户交互(如点击、输入),并更新数据和界面。
  1. 同步机制
  • 需要确保数据变化后界面及时更新(MVC 通过观察者模式,MVVM 通过数据绑定)。

2.区别

特性MVCMVVM
核心组件Model、View、ControllerModel、View、ViewModel
数据流方向单向:用户操作 → Controller → Model → View双向:View ↔ ViewModel ↔ Model(自动同步)
界面更新方式手动更新(需显式调用 View 刷新逻辑)自动更新(通过数据绑定)
适用场景复杂交互控制(如桌面应用)数据驱动型 UI(如动态表单、实时仪表盘)
耦合度View 和 Controller 可能耦合较紧View 和 ViewModel 完全解耦
典型框架Qt Widgets、Spring MVCQt QML、WPF、Vue.js

3.交互流程

1. MVC模式交互流程

  1. 用户操作触发 View 的事件(如点击按钮)。

  2. Controller 接收事件,调用 Model 修改数据。

  3. Model 更新后通知 View 刷新界面(通过观察者模式或直接调用)。


2. MVVM交互流程

  1. View 通过数据绑定直接关联 ViewModel 的属性(如 QML 的 text: viewModel.name)。

  2. 用户修改 View(如输入文本),自动更新 ViewModel。

  3. ViewModel 修改 Model,Model 变化后通过信号通知 ViewModel,触发 View 自动更新。


4.总结

  • 选择 MVC
    适合需要精细控制交互逻辑的桌面应用(如复杂表单验证、多窗口管理)。

  • 选择 MVVM
    适合数据驱动且界面频繁更新的场景(如实时监控、动态仪表盘)。

  • Qt 的灵活性

    • 在 QWidgets 中,MVC 更常见,但需手动管理数据流。

    • 在 QML 中,MVVM 是自然选择,利用其声明式语法和数据绑定特性。


http://www.kler.cn/a/549643.html

相关文章:

  • 【漫话机器学习系列】092.模型的一致性(Consistency of a Model)
  • 国产FPGA开发板选择
  • Spring Boot实战:拦截器
  • 2025百度快排技术分析:模拟点击与发包算法的背后原理
  • yarn add electron --dev --platform=win64 报错 certificate has expired 2025年 解决办法
  • 消息队列(MQ)核心知识与应用场景解析
  • oracle使用动态sql将多层级组织展平
  • git仓库拉取最新更改
  • 拉分支提示git变基全套解决方案
  • Day65_20250213图论part9_dijkstra(堆优化版)|Bellman_ford算法精讲
  • 神经网络新手入门(3)光明顶复出(2006-2012)
  • 网络共享基于什么原理,为什么MAC可以编辑局域网的windows系统文件?
  • 从零开始在Windows系统上搭建一个node.js后端服务项目
  • 基于Ubuntu+vLLM+NVIDIA T4高效部署DeepSeek大模型实战指南
  • SQL注入之布尔盲注+时间盲注
  • 【数据库维护】Clickhouse数据库维护关键系统表相关指标说明,支撑定位慢SQL及多实例场景下分析各实例运行情况
  • Qt使用pri和pro文件进行模块化编程
  • 机器学习·逻辑回归
  • 华为昇腾920b服务器部署DeepSeek翻车现场
  • IPv4 协议和TCP 协议的区别