首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

在不使用System.Windows.Input.ICommand的情况下在WPF中实现MVVM

在不使用 System.Windows.Input.ICommand 的情况下,在 WPF 中实现 MVVM 模式可以通过以下方式实现:

  1. 创建一个事件触发器(EventTrigger),并将其绑定到 View 层的 UI 元素上。
  2. 在 ViewModel 层中创建一个命令(Command),该命令将在事件触发器被触发时执行。
  3. 使用命令参数(CommandParameter)将 View 层的 UI 元素与 ViewModel 层的命令进行绑定。

以下是一个简单的示例:

首先,在 View 层的 XAML 文件中创建一个按钮,并为其添加一个事件触发器:

代码语言:xml<Button Content="Click me">
复制
    <i:Interaction.Triggers>
        <i:EventTrigger EventName="Click">
            <i:InvokeCommandAction Command="{Binding MyCommand}" CommandParameter="{Binding ElementName=MyButton}"/>
        </i:EventTrigger>
    </i:Interaction.Triggers>
</Button>

其中,iSystem.Windows.Interactivity 命名空间的 XML 命名空间声明,需要在 XAML 文件的根元素中添加:

代码语言:xml
复制
xmlns:i="http://schemas.microsoft.com/expression/2010/interactivity"

接下来,在 ViewModel 层中创建一个命令,并在其中实现业务逻辑:

代码语言:csharp
复制
public class MyViewModel : INotifyPropertyChanged
{
    public event PropertyChangedEventHandler PropertyChanged;

    private ICommand myCommand;

    public ICommand MyCommand
    {
        get
        {
            if (myCommand == null)
            {
                myCommand = new RelayCommand(param => this.ExecuteMyCommand(param));
            }

            return myCommand;
        }
    }

    private void ExecuteMyCommand(object parameter)
    {
        // 在此处实现业务逻辑
    }
}

最后,将 ViewModel 层的实例绑定到 View 层的 DataContext 中:

代码语言:csharp
复制
public partial class MainWindow : Window
{
    public MainWindow()
    {
        InitializeComponent();
        this.DataContext = new MyViewModel();
    }
}

这样,当用户点击按钮时,就会触发 ViewModel 层中的命令,并执行相应的业务逻辑。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

  • WPF NET5 Prism8.0的升级指南

    ​ 曾经我以学习的目的写了关于在.NET Core3.1使用Prism的系列文章.NET Core 3 WPF MVVM框架 Prism系列文章索引,也谢谢大家的支持,事实上当初的版本则是Prism7.2.0.1442(7.2)版本,而现在也发布了.NET5和最新的Prism8.0.0.1909(8.0)版本,因此同样的我想将之前的Prism Demo项目可以升级到最新,写这篇文章的目的是自己也能学习一番,而更多的是回答那些在我Prism系列文章下面留下的我认为可以拿来一讲一些问题,而有些问题我则是水平有限回答不了(真的不是不想回答)  然后我拿之前的Prism Demo项目,WPF从.NET Core3.1升级到.NET 5其实非常简单,无脑修改项目的TargetFramework为net5.0-windows就行了,但是当Prism7.2升级到Prism8.0,我发现build的时候报了很多错误,那么让我们来看看究竟Prism8.0更新了些啥

    04

    【译】基于XAML的跨平台框架对比分析

    多年来,基于XAML的UI框架已经有了很大的发展。下面的图表是最好的说明。这些框架主要包含:支持跨平台应用的Avalonia UI, Uno Platform和 .NET MAUI。事实上,除了Avalonia UI之外,对跨平台XAML的需求是其发展的主要驱动力。如果微软早点推出一个类似Flutter这样的跨平台UI框架,我们可能就不会有这个么多的选择。这样有利有弊:好处在于我们选择有很多跨平台方案可以选择,坏处在于不同的框架有不同的对象模型以及各自的特有的XAML语法(dialect of XAML)。 在关注各种 .NET UI 框架时,我们会提出同一个问题:应该使用哪一个XAML UI框架来开发我们的应用?这是一个合理且重要的问题。迄今为止还没有一个明确的答案。但是,对于每个具体的应用,这个问题很容易回答,因为可以针对特定的应用需求比较分析每一种框架的优点和缺点。通过概述基于 XAML 的主要 UI 框架的优点和缺点,本文档旨在帮助公司和开发人员回答以下问题:

    02

    MVVM模式和在WPF中的实现(一)MVVM模式简介

    之前一直用Winform。刚开始看了下感觉跟Winform区别不大,控件可以拖进去,选中了控件属性面板可以设置属性、事件面板可以监听事件,后台代码处理事件,一切都那么的熟悉。XAML布局也跟Android布局很像,所以没学习就直接开始了,觉得摸索摸索基本就差不多了吧。结果各种不适应,拖控件拖进去后总是调整不好显示方式,控件在后台代码中操作找不到方法,对于WPF介绍的各种特点也毫无体会,总想着换回去。后来看了刘铁猛的《深入浅出WPF》,里面说WPF就要用WPF的方式来开发。这才认真开始学WPF。现在控件面板和属性面板都已经用的很少了,界面布局基本全部用代码搞定,感觉任何一个细节都能控制到。再后来接触到了MVVM,更加体会到了以MVVM模式开发WPF带来的好处。现在除非要求已经不再用Winform了,小工具和测试程序直接在后台写代码,复杂一点的需要长期使用和维护的用MVVM模式。这个系列的文章主要写一下自己对MVVM的理解和核心部分的简易实现方式。

    02
    领券