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

WPF中的MVVM设计模式

文章目录

    • 一,什么是MVVM?
    • 二,MVVM 的核心机制:数据绑定 + 通知机制
      • 1,数据绑定(Data Binding)
      • 属性变更通知(INotifyPropertyChanged)
    • 三,MVVM各层的职责划分
    • 四,手动实现一个SetProperty 和通知
      • 1.创建 BaseViewModel.cs
      • 2. ViewModel类继承它
    • 五,引入外部库
    • 六,总结

一,什么是MVVM?

 MVVM 是一种设计模式,全称是 Model-View-ViewModel,它的目的是实现 界面与业务逻辑的分离。
它将代码分为三部分:

层次作用
Model数据模型层,代表业务逻辑和数据结构,通常是 POCO 类或实体类。
View视图层,用户界面(例如 XAML 页面)。它只负责展示内容。
ViewModel视图模型层,负责连接 View 和 Model,是数据绑定的桥梁。

MVVM 的核心思想是:让 UI 自动响应数据变化,而不是写死在代码里

二,MVVM 的核心机制:数据绑定 + 通知机制

1,数据绑定(Data Binding)

 MVVM 的精髓在于:绑定数据,而不是控制 UI。
 通过 WPF/XAML 中的 {Binding},你可以将 UI 控件直接绑定到 ViewModel 的属性上。

<TextBox Text="{Binding UserName}" />

 只要 UserName 属性发生变化,界面就会自动更新。

属性变更通知(INotifyPropertyChanged)

 为了让 UI 能感知属性的变化,ViewModel 通常实现 INotifyPropertyChanged 接口。
标准写法:

public class MyViewModel : INotifyPropertyChanged
{private string userName;public string UserName{get => userName;set{if (userName != value){userName = value;OnPropertyChanged(nameof(UserName));}}}public event PropertyChangedEventHandler PropertyChanged;protected void OnPropertyChanged(string propertyName) =>PropertyChanged?.Invoke(this, new PropertyChangedEventArgs(propertyName));
}

为了简化重复代码,常常会使用 SetProperty 辅助方法(比如来自 Prism、CommunityToolkit.Mvvm 等库):

protected bool SetProperty<T>(ref T storage, T value, [CallerMemberName] string propertyName = null)
{if (Equals(storage, value)) return false;storage = value;OnPropertyChanged(propertyName);return true;
}

三,MVVM各层的职责划分

  • View (视图)
    • 通常是.xaml文件
    • 不包含业务逻辑,仅负责UI展示
    • 通过 DataContext 绑定到 ViewModel。
  • ViewModel(视图模型)
    • 承担 UI 的逻辑。
    • 提供属性、命令(Command)等供绑定。
    • 不知道 View 的具体内容,但知道自己暴露了哪些可以供 UI 使用的功能。
  • Model(模型)
    • 是数据结构、实体类、服务调用逻辑的封装。
    • 完全独立于 UI。

四,手动实现一个SetProperty 和通知

 如果你不想引用 MVVM 框架,可以按以下方式定义一个基础类:

1.创建 BaseViewModel.cs

using System.ComponentModel;
using System.Runtime.CompilerServices;public class BaseViewModel : INotifyPropertyChanged
{public event PropertyChangedEventHandler PropertyChanged;protected void OnPropertyChanged(string propertyName){PropertyChanged?.Invoke(this, new PropertyChangedEventArgs(propertyName));}protected void SetProperty<T>(ref T item, T value, [CallerMemberName] string propertyName = 		null){if (!EqualityComparer<T>.Default.Equals(item, value){item = value;OnPropertyChanged(propertyName);}}
}

2. ViewModel类继承它

public class MyViewModel : BaseViewModel
{private int textBox_TempDelay_;public int textBox_TempDelay{get => textBox_TempDelay_;set => SetProperty(ref textBox_TempDelay_, value);}
}

五,引入外部库

 使用NuGet包管理器

Install-Package CommunityToolkit.Mvvm
using CommunityToolkit.Mvvm.ComponentModel;public partial class MyViewModel : ObservableObject
{private int textBox_TempDelay_;public int textBox_TempDelay{get => textBox_TempDelay_;set => SetProperty(ref textBox_TempDelay_, value);}
}

六,总结

 MVVM 模式是现代 UI 应用程序设计的基石,特别适合像 WPF、UWP、MAUI、Xamarin 这类数据绑定驱动的框架。通过明确的层次分离和数据驱动的 UI 机制,开发者可以更轻松地构建复杂而健壮的应用。

相关文章:

  • 做首饰网站网上电商平台开发
  • 东莞网站的制作设计百度安装应用
  • 什么网站可以做全景图seo权威入门教程
  • seo网站搜索优化seo公司
  • 临夏州住房和城乡建设局网站博客seo优化技术
  • 台州网站设计成品短视频app下载有哪些软件
  • 解锁Selenium:Web自动化的常用操作秘籍
  • 第九节 CSS工程化-预处理技术对比
  • DVWA Brute Force漏洞深度分析与利用指南
  • C# VB.NET中Tuple轻量级数据结构和固定长度数组
  • 秋招Day14 - MySQL - 场景题
  • RabbitMQ 利用死信队列来实现延迟消息
  • Linux Sonic Agent 端部署(详细版)(腾讯云)
  • Google Cloud Platform(GCP)实例中使用显卡信息报错问题
  • 裸机项目添加FreeRTOS操作系统--常见报错
  • Kubernetes生命周期管理:深入理解 Pod 生命周期
  • Aerotech系列(4)Aerotech.A3200名空间
  • SpringBoot + MyBatis 事务管理全解析:从 @Transactional 到 JDBC Connection 的旅程
  • Airtable 的数据超出上限,3 种常见应对方式
  • 较大项目 git(gitee, github) 拉取失败解决方法
  • Linux系统环境编程
  • NHDeep智能档案题名(标题)校对工具使用说明
  • Linux线程概念及常用接口(1)
  • Redis 乱码和LocalDateTime类型缓存问题
  • 电商领域企业级应用后端开发 (Java) 就业前景深度分析报告 (2025-2030)
  • uniapp项目之小兔鲜儿小程序商城(六) 地址模块:地址管理页的实现,地址表单页的实现