0

0

C# WPF中的MVVM模式是什么 - 数据绑定与命令的实现

畫卷琴夢

畫卷琴夢

发布时间:2025-12-06 19:38:03

|

466人浏览过

|

来源于php中文网

原创

MVVM是WPF中分离UI与业务逻辑的架构模式,由View(XAML界面)、ViewModel(封装逻辑并实现INotifyPropertyChanged和ICommand)和Model(数据与业务)组成,依托数据绑定和命令机制实现解耦。

c# wpf中的mvvm模式是什么 - 数据绑定与命令的实现

MVVM(Model-View-ViewModel)是WPF中一种广泛应用的架构模式,旨在分离用户界面逻辑与业务逻辑,提升代码的可维护性、可测试性和可重用性。它的核心在于通过数据绑定和命令机制,让View(视图)与ViewModel(视图模型)解耦。

1. MVVM 的基本结构

View(视图):即XAML页面,负责UI展示和用户交互。它不直接操作数据或逻辑,而是通过绑定依赖属性来显示数据,并通过命令响应用户操作。

ViewModel(视图模型):位于View和Model之间,暴露公共属性和命令供View绑定,封装界面逻辑,比如数据验证、状态管理等。它通常实现 INotifyPropertyChanged 接口以支持数据绑定更新。

Model(模型):代表应用程序的数据和业务逻辑,如实体类、数据访问层等,不关心UI细节。

2. 数据绑定的实现

WPF的数据绑定是MVVM的核心。当ViewModel中的数据发生变化时,View能自动更新,前提是属性触发了通知事件。

实现方式如下:

  • ViewModel类实现 INotifyPropertyChanged 接口。
  • 在属性的setter中调用 PropertyChanged 事件,通知WPF属性已更改。
示例代码:
public class PersonViewModel : INotifyPropertyChanged
{
    private string _name;
    public string Name
    {
        get => _name;
        set
        {
            _name = value;
            OnPropertyChanged(nameof(Name));
        }
    }

    public event PropertyChangedEventHandler PropertyChanged;

    protected virtual void OnPropertyChanged(string propertyName)
    {
        PropertyChanged?.Invoke(this, new PropertyChangedEventArgs(propertyName));
    }
}

在XAML中绑定:

这样,当文本框输入变化时,Name属性会自动更新;反之,代码中修改Name,界面也会刷新。

68爱写
68爱写

专业高质量AI4.0论文写作平台,免费生成大纲,支持无线改稿

下载

3. 命令(ICommand)的实现

在MVVM中,按钮点击等操作不能使用传统事件处理(如Click事件),而应通过命令绑定,保持View不包含逻辑代码。

使用 ICommand 接口将动作封装为属性,推荐使用 RelayCommandDelegateCommand 简化实现。

自定义 RelayCommand 示例:
public class RelayCommand : ICommand
{
    private readonly Action _execute;
    private readonly Func _canExecute;

    public RelayCommand(Action execute, Func canExecute = null)
    {
        _execute = execute;
        _canExecute = canExecute;
    }

    public bool CanExecute(object parameter) => _canExecute == null || _canExecute();

    public void Execute(object parameter) => _execute();

    public event EventHandler CanExecuteChanged
    {
        add { CommandManager.RequerySuggested += value; }
        remove { CommandManager.RequerySuggested -= value; }
    }
}

在ViewModel中定义命令:

public ICommand SaveCommand { get; private set; }

public PersonViewModel()
{
    SaveCommand = new RelayCommand(Save, CanSave);
}

private void Save()
{
    // 执行保存逻辑
}

private bool CanSave() => !string.IsNullOrWhiteSpace(Name);

XAML中绑定命令:

此时按钮是否可用会根据 CanSave() 返回值动态更新。

4. 实际应用建议

  • 使用NuGet包如 CommunityToolkit.Mvvm(原MvvmHelpers)可简化 ViewModel 基类和命令的编写。
  • 避免在View中写后台代码(code-behind),除非必须操作UI元素。
  • 合理使用 ObservableCollection 绑定列表数据,确保集合变更也能反映到界面。

基本上就这些。掌握数据绑定和命令机制,就能在WPF中高效使用MVVM模式,写出清晰、易测的界面代码。

相关专题

更多
硬盘接口类型介绍
硬盘接口类型介绍

硬盘接口类型有IDE、SATA、SCSI、Fibre Channel、USB、eSATA、mSATA、PCIe等等。详细介绍:1、IDE接口是一种并行接口,主要用于连接硬盘和光驱等设备,它主要有两种类型:ATA和ATAPI,IDE接口已经逐渐被SATA接口;2、SATA接口是一种串行接口,相较于IDE接口,它具有更高的传输速度、更低的功耗和更小的体积;3、SCSI接口等等。

1047

2023.10.19

PHP接口编写教程
PHP接口编写教程

本专题整合了PHP接口编写教程,阅读专题下面的文章了解更多详细内容。

86

2025.10.17

php8.4实现接口限流的教程
php8.4实现接口限流的教程

PHP8.4本身不内置限流功能,需借助Redis(令牌桶)或Swoole(漏桶)实现;文件锁因I/O瓶颈、无跨机共享、秒级精度等缺陷不适用高并发场景。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

455

2025.12.29

java接口相关教程
java接口相关教程

本专题整合了java接口相关内容,阅读专题下面的文章了解更多详细内容。

11

2026.01.19

Java编译相关教程合集
Java编译相关教程合集

本专题整合了Java编译相关教程,阅读专题下面的文章了解更多详细内容。

9

2026.01.21

C++多线程相关合集
C++多线程相关合集

本专题整合了C++多线程相关教程,阅读专题下面的的文章了解更多详细内容。

3

2026.01.21

无人机驾驶证报考 uom民用无人机综合管理平台官网
无人机驾驶证报考 uom民用无人机综合管理平台官网

无人机驾驶证(CAAC执照)报考需年满16周岁,初中以上学历,身体健康(矫正视力1.0以上,无严重疾病),且无犯罪记录。个人需通过民航局授权的训练机构报名,经理论(法规、原理)、模拟飞行、实操(GPS/姿态模式)及地面站训练后考试合格,通常15-25天拿证。

13

2026.01.21

Python多线程合集
Python多线程合集

本专题整合了Python多线程相关教程,阅读专题下面的文章了解更多详细内容。

1

2026.01.21

java多线程相关教程合集
java多线程相关教程合集

本专题整合了java多线程相关教程,阅读专题下面的文章了解更多详细内容。

3

2026.01.21

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PostgreSQL 教程
PostgreSQL 教程

共48课时 | 7.5万人学习

Django 教程
Django 教程

共28课时 | 3.3万人学习

Excel 教程
Excel 教程

共162课时 | 12.6万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号