WPF入门教学十三 MVVM模式简介

news/2024/11/17 3:29:26/

MVVM(Model-View-ViewModel)是一种软件架构设计模式,特别适用于WPF和UWP等UI框架。MVVM模式的主要目标是将UI逻辑与业务逻辑分离,从而提高代码的可测试性、可维护性和可重用性。以下是MVVM模式的简介和示例。

MVVM模式简介

Model(模型)
  • 定义:模型代表应用程序的数据和业务逻辑。
  • 职责:处理数据的获取、存储和处理,以及业务规则的实现。
View(视图)
  • 定义:视图是用户界面,负责显示数据和接收用户输入。
  • 职责:通过数据绑定显示模型的数据,并将用户的操作传递给视图模型。
ViewModel(视图模型)
  • 定义:视图模型是模型和视图之间的桥梁,负责处理视图的业务逻辑。
  • 职责
    • 提供数据绑定所需的属性和命令。
    • 处理视图的交互逻辑。
    • 实现INotifyPropertyChanged接口以通知视图数据的变化。

MVVM模式的优势

  • 分离关注点:将UI逻辑与业务逻辑分离,使代码更易于理解和维护。
  • 可测试性:视图模型可以独立于视图进行单元测试。
  • 可重用性:视图模型可以在不同的视图中重用。

示例

Model(模型)

假设我们有一个简单的Person类:

 
public class Person
{public string Name { get; set; }public int Age { get; set; }
}
ViewModel(视图模型)

接下来,我们创建一个PersonViewModel,它包含一个Person对象和一些命令:

 
public class PersonViewModel : INotifyPropertyChanged
{private Person _person;public Person Person{get { return _person; }set{if (_person != value){_person = value;OnPropertyChanged(nameof(Person));}}}public ICommand SaveCommand { get; }public PersonViewModel(){Person = new Person();SaveCommand = new RelayCommand(Save);}private void Save(){// Save logic hereMessageBox.Show("Person saved!");}public event PropertyChangedEventHandler PropertyChanged;protected virtual void OnPropertyChanged(string propertyName){PropertyChanged?.Invoke(this, new PropertyChangedEventArgs(propertyName));}
}

注意:这里使用了RelayCommand,它是MVVM中常用的命令实现方式。你可以自己实现一个简单的RelayCommand,或者使用第三方库如MVVMLight或Prism。

View(视图)

最后,我们在XAML中创建一个视图来显示Person的信息,并绑定命令:

 
<Window x:Class="WpfApp.MainWindow"xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"xmlns:local="clr-namespace:WpfApp"Title="MVVM Example" Height="350" Width="525"><Window.DataContext><local:PersonViewModel/></Window.DataContext><Grid><StackPanel><TextBox Text="{Binding Person.Name, UpdateSourceTrigger=PropertyChanged}"/><TextBox Text="{Binding Person.Age, UpdateSourceTrigger=PropertyChanged}"/><Button Content="Save" Command="{Binding SaveCommand}"/></StackPanel></Grid>
</Window>

总结

通过上述示例,我们可以看到MVVM模式如何将UI逻辑与业务逻辑分离。视图模型负责处理业务逻辑,并通过数据绑定与视图进行交互。这种设计模式使得代码更加模块化,易于测试和维护。


http://www.ppmy.cn/news/1531691.html

相关文章

2024.9.27 Python面试八股文

1.列表操作&#xff1a; 1.列表.pop(index) 这样可以pop指定下标的元素 2.列表.reverse() 列表翻转 3.列表名.count(数据)&#xff1a;数据在列表中出现的次数。 In [56]: a [11, 22, 11, 33, 11] In [57]: a.count(11) Out[57]: 34.列表名.index(数据)&#xff1a;数据在列…

代码随想录_刷题笔记_第三次

字符串 — KMP算法&#xff08;理论&#xff09; **解决问题&#xff1a;**字符串匹配的问题&#xff08;eg&#xff1a;文本串 aabaabaaf 模式串 aabaaf 求在文本串中是否出现过模式串&#xff09; **暴力匹配&#xff1a;**当 b 和 f 不匹配时&#xff0c;整体向后跳一位再进…

java项目之健身房管理系统源码(springboot)

风定落花生&#xff0c;歌声逐流水&#xff0c;大家好我是风歌&#xff0c;混迹在java圈的辛苦码农。今天要和大家聊的是一款基于springboot的健身房管理系统。项目源码以及部署相关请联系风歌&#xff0c;文末附上联系信息 。 项目简介&#xff1a; 健身房管理系统的主要使用…

linux配置git

一、生成新的 SSH 密钥 ssh-keygen -t rsa -b 4096 -C "your_emailexample.com" 按照提示操作&#xff1a; 当提示 Enter file in which to save the key (/root/.ssh/id_rsa): 时&#xff0c;直接按回车键使用默认路径。 当提示 Enter passphrase (empty for no p…

《AI系统:原理与架构》于华为HC大会2024正式发布

2024年9月21日&#xff0c;《AI系统&#xff1a;原理与架构》新书发布会在上海世博馆华为HC大会顺利举办。本书由华为昇腾技术专家、B站AI科普博主ZOMI酱和哈工大软件学院副院长苏统华教授联合编写&#xff0c;是领域内AI系统方面填补空白的重磅之作。 发布会上&#xff0c;《A…

【第二十章:Sentosa_DSML社区版-机器学习之自动建模】

目录 20.1 自动回归 20.2 自动分类 20.3 自动聚类 20.4 AutoARIMA 20.5 自动数据准备 【第二十章&#xff1a;Sentosa_DSML社区版-机器学习之自动建模】 20.1 自动回归 1.算子介绍 为了方便用户在不了解每个具体回归算法原理&#xff0c;及每个算法参数设置具体含义的情…

使用脚本自动化管理外部Git仓库依赖

在软件开发中&#xff0c;管理外部Git仓库的依赖是一项常见且重要的任务。随着项目的发展&#xff0c;这些外部仓库可能会频繁更新&#xff0c;包含重要的修复或新功能。手动更新这些依赖的提交哈希值不仅耗时&#xff0c;而且容易出错。为了解决这个问题&#xff0c;我们可以编…

WebAPI编程(第三天,第四天)

WebAPI编程&#xff08;第三天&#xff0c;第四天&#xff09; day03 - Web APIs1.1. 节点操作1.1.1 删除节点1.1.2 案例&#xff1a;删除留言1.1.3 复制&#xff08;克隆&#xff09;节点1.1.4 案例&#xff1a;动态生成表格1.1.5 创建元素的三种方式1.1.6 innerTHML和createE…