wpf之触发器

 

 示例:

复制代码
<Window x:Class="MyWpf.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:MyWpf"
        mc:Ignorable="d" 
        Title="MainWindow" Height="250" Width="500">
    <Window.Resources>
        <!--表示这个样式只针对于Button标签,这个样式的key值是BaseStyle,
        -->
        <Style TargetType="TextBox" x:Key="BaseStyle">
            <Setter Property="Foreground" Value="Red"></Setter>
            <Setter Property="HorizontalAlignment" Value="Left"></Setter>
            <Setter Property="VerticalAlignment" Value="Top"></Setter>
            <Setter Property="Width" Value="75"></Setter>

            <Style.Triggers>
                <!--如果鼠标移动到button上方,对当前按钮样式进行更改-->
                <Trigger Property="IsMouseOver" Value="True">
                    <Setter Property="FontSize" Value="22"></Setter>
                    <Setter Property="Foreground" Value="Blue"></Setter>
                </Trigger>
                <!--多条件出发-->
                <MultiTrigger>
                    <!--只有鼠标在按钮上方并且选中才会触发事件-->
                    <MultiTrigger.Conditions>
                        <Condition Property="IsFocused" Value="True"></Condition>
                        <Condition Property="IsMouseOver" Value="True"></Condition>
                    </MultiTrigger.Conditions>
                    <!--触发事件之后的样式-->
                    <MultiTrigger.Setters>
                        <Setter Property="FontSize" Value="22"></Setter>
                        <Setter Property="Foreground" Value="Blue"></Setter>
                    </MultiTrigger.Setters>
                </MultiTrigger> 
                
                <!--数据变化触发器 如果值等于123的时候触发事件-->
                <DataTrigger Binding="{Binding RelativeSource={RelativeSource Mode=Self},Path=Text}  " Value="123">
                    <Setter Property="Foreground" Value="Blue"></Setter>
                </DataTrigger>
            </Style.Triggers>
        </Style>
        <!--表示这个样式继承于BaseStyle-->
        <Style x:Key="style1" TargetType="TextBox" BasedOn="{StaticResource ResourceKey=BaseStyle}" >
        </Style>
    </Window.Resources>
    <Grid>
        <TextBox Style="{StaticResource ResourceKey=style1}"  />
        <TextBox Style="{StaticResource ResourceKey=style1}" Margin="0,75,0,0"  />
        <TextBox Style="{StaticResource ResourceKey=style1}" Margin="0,35,0,0"    /> 
    </Grid>
</Window>
复制代码

 

 

 

 

 

 

v

posted @   安静点--  阅读(57)  评论(0编辑  收藏  举报
编辑推荐:
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
阅读排行:
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构
· 字符编码:从基础到乱码解决
· 提示词工程——AI应用必不可少的技术
点击右上角即可分享
微信分享提示