C#与WPF使用mvvm简单案例点击按钮触发弹窗

创建WPF工程文件,以mvvm模式更改页面名称,及创建model类

注意页面的命名以View结尾,模型类以ViewModel结尾

安装 Prism.Core

页面添加一个按钮

XML 复制代码
<Window x:Class="MVVMDemo.Views.MainWindowView"
        xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
        xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
        xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
        xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
        xmlns:local="clr-namespace:MVVMDemo"
        mc:Ignorable="d"
        Title="MainWindow" Height="450" Width="800">
    <Grid>
        <Border>
            <Button Content="测试按钮" 
                        Command="{Binding TestCommand}"  
                        CommandParameter="{Binding RelativeSource={RelativeSource AncestorType=Window}}" 
                        Width="90" Height="50" FontSize="20" />
        </Border>
    </Grid>
</Window>

页面后台代码

cs 复制代码
using MVVMDemo.ViewModels;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Windows;
using System.Windows.Controls;
using System.Windows.Data;
using System.Windows.Documents;
using System.Windows.Input;
using System.Windows.Media;
using System.Windows.Media.Imaging;
using System.Windows.Navigation;
using System.Windows.Shapes;

namespace MVVMDemo.Views
{
    /// <summary>
    /// MainWindow.xaml 的交互逻辑
    /// </summary>
    public partial class MainWindowView : Window
    {
        public MainWindowView()
        {
            InitializeComponent();

            //绑定数据源
            DataContext = new MainWindowViewModel();
        }
    }
}

MainWindowViewModel代码

cs 复制代码
using Prism.Commands;
using Prism.Mvvm;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Windows;
using System.Windows.Input;

namespace MVVMDemo.ViewModels
{
    public class MainWindowViewModel : BindableBase
    {
        //测试按钮命令
        public ICommand TestCommand
        {
            get => new DelegateCommand(Test);
        }

        private void Test()
        {
            MessageBox.Show("有效触发", "测试mvvm");

        }
    }
}

运行效果

相关推荐
阿登林29 分钟前
C# .NET Core中Chart图表绘制与PDF导出
c#·1024程序员节
Elieal31 分钟前
Java的Collection 集合体系详解
java·开发语言
charlie1145141911 小时前
HTML 理论笔记
开发语言·前端·笔记·学习·html·1024程序员节
郝学胜-神的一滴1 小时前
Linux中的`fork`函数详解:深入解析
linux·服务器·开发语言·c++·算法
曾凡宇先生2 小时前
无法远程连接 MySQL
android·开发语言·数据库·sql·tcp/ip·mysql·adb
Q一件事3 小时前
R语言随机森林分析显示R方和P值
开发语言·随机森林·r语言
Mr.Jessy3 小时前
JavaScript学习第六天:函数
开发语言·前端·javascript·学习·html·1024程序员节
Aevget3 小时前
DevExpress WPF中文教程:Data Grid - 如何使用虚拟源?(三)
wpf·界面控件·devexpress·ui开发·1024程序员节
九皇叔叔4 小时前
Java循环结构全解析:从基础用法到性能优化
java·开发语言·性能优化
sulikey4 小时前
Qt 入门简洁笔记:从框架概念到开发环境搭建
开发语言·前端·c++·qt·前端框架·visual studio·qt框架