wpf之Interaction.Triggers

前言

在wpf中 Interaction.Triggers是对命令的补充,命令能应用的场合有限,比如Button的单击事件,但是像window窗体的Loaded事件,TextBox的TextChanged就无法使用命令。Interaction.Triggers的结构如下:

csharp 复制代码
<控件>
    <i:Interaction.Triggers>
        <触发器类型>
            <动作类型 属性="值"/>
        </触发器类型>
    </i:Interaction.Triggers>
</控件>

1、引用dll

在NuGet包管理器中选择Microsoft.Xaml.Behaviors.Wpf这个包安装

2、引用命名空间

在xaml代码中加上如下代码

csharp 复制代码
 xmlns:Event="http://schemas.microsoft.com/xaml/behaviors"

3、window的Loaded事件

下面的代码中EventName指定了需要绑定的事件的名称,这里是"Loaded"事件。在InvokeCommandAction的Command属性中绑定事件CommandWindowLoaded,这里的CommandWindowLoaded在ViewModel类中定义和实例化。

csharp 复制代码
<Window x:Class="wpf之Interaction.Triggers.MainWindow"
        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:wpf之Interaction.Triggers"
        xmlns:Event="http://schemas.microsoft.com/xaml/behaviors"
        mc:Ignorable="d"
        Title="MainWindow" Height="450" Width="800">
    <Event:Interaction.Triggers>
        <Event:EventTrigger EventName="Loaded">
            <Event:InvokeCommandAction Command="{Binding CommandWindowLoaded}"/>
        </Event:EventTrigger>
    </Event:Interaction.Triggers>
    <Grid>
       
    </Grid>
</Window>

自定义命令DelegateCommand

csharp 复制代码
public class DelegateCommand : ICommand
    {
        private readonly Action<object> _execute;
        private readonly Func<object, bool> _canExecute;

        public DelegateCommand(Action<object> execute, Func<object, bool> canExecute = null)
        {
            _execute = execute ?? throw new ArgumentNullException(nameof(execute));
            _canExecute = canExecute;
        }

        public bool CanExecute(object parameter)
        {
            if (_canExecute != null)
            {
                return _canExecute(parameter);
            }
            else
            {
                return true;
            }
        }

        public void Execute(object parameter)
        {
            _execute(parameter);
        }


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

定义ViewMode的基类ViewModelBase

csharp 复制代码
 public class ViewModelBase : INotifyPropertyChanged
    {
        public event PropertyChangedEventHandler PropertyChanged;

        public void OnPropertyChanged(string propname)
        {
            if (PropertyChanged != null)
            {
                PropertyChanged(this, new PropertyChangedEventArgs(propname));
            }
        }

    }

定义ViewMode并且继承ViewModelBase,在ViewMode中实例化一个命令,

csharp 复制代码
 public class ViewModel : ViewModelBase
    {

        public ICommand CommandWindowLoaded { get; set; }
        public ViewModel()
        {
            CommandWindowLoaded = new DelegateCommand(WindowLoaded);
        }

        public void WindowLoaded(object param)
        {
            Console.WriteLine("窗体加载");
        }
    }

4、TextBox的TextChanged事件

当你改变TextBox内容的时候,不停的就会触发TextChangedCommand命令执行。

下面的代码同样是通过EventName指定需要绑定的事件类型,通过Command属性来绑定ViewModel中具体的事件,同时还可以传递参数。

csharp 复制代码
<Window x:Class="wpf之Interaction.Triggers.MainWindow"
        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:wpf之Interaction.Triggers"
        xmlns:Event="http://schemas.microsoft.com/xaml/behaviors"
        mc:Ignorable="d"
        Title="MainWindow" Height="450" Width="800">
    <Event:Interaction.Triggers>
        <Event:EventTrigger EventName="Loaded">
            <Event:InvokeCommandAction Command="{Binding CommandWindowLoaded}"/>
        </Event:EventTrigger>
    </Event:Interaction.Triggers>
    <Grid>
        <StackPanel >
            <TextBox x:Name="tbx_test" Height="20" Width=" 40">
                <Event:Interaction.Triggers>
                    <Event:EventTrigger EventName="TextChanged">
                        <Event:InvokeCommandAction Command="{Binding TextChangedCommand}" CommandParameter="{Binding Path=Text,ElementName=tbx_test}"/>
                    </Event:EventTrigger>
                </Event:Interaction.Triggers>
            </TextBox >
        </StackPanel >
    </Grid>
</Window>
csharp 复制代码
 public class ViewModel : ViewModelBase
    {

        public ICommand CommandWindowLoaded { get; set; }
        public ICommand TextChangedCommand { get; set; }
        public ViewModel()
        {
            CommandWindowLoaded = new DelegateCommand(WindowLoaded);
            TextChangedCommand= new DelegateCommand(TextChange);
        }

        public void WindowLoaded(object param)
        {
            Console.WriteLine("窗体加载");
        }


        public void TextChange(object param)
        {
            Console.WriteLine($"文本修改{param}");
        }
    }

马工撰写的年入30万+C#上位机项目实战必备教程(点击下方链接即可访问文章目录)

1、《C#串口通信从入门到精通》

2、《C#与PLC通信从入门到精通 》

3、《C# Modbus通信从入门到精通》

4、《C#Socket通信从入门到精通 》

5、《C# MES通信从入门到精通》

6、《winform控件从入门到精通》

7、《C#操作MySql数据库从入门到精通》

相关推荐
.房东的猫3 小时前
ERP(金蝶云星空)开发【安装篇】
c#
fie888912 小时前
基于C#的推箱子小游戏实现
开发语言·c#
.房东的猫12 小时前
ERP(金蝶云星空)开发【业务数据中心创建和注册】
c#
bugcome_com12 小时前
C# 进阶核心知识点汇总|多项目开发 + 委托 + Lambda + 事件一次吃透
c#
SunflowerCoder15 小时前
基于插件化 + Scriban 模板引擎的高效 HTTP 协议中心设计
http·c#
就是有点傻17 小时前
WPF按钮走马灯效果
wpf
zuozewei17 小时前
虚拟电厂聚合商平台安全技术体系深度解读
安全·wpf
极客智造17 小时前
WPF 自定义控件:AutoGrid 实现灵活自动布局的网格控件
wpf
极客智造18 小时前
WPF Grid 布局高效扩展:GridHelpers 附加属性工具类全解析
wpf
张人玉18 小时前
WPF 多语言实现完整笔记(.NET 4.7.2)
笔记·.net·wpf·多语言实现·多语言适配