【问题标题】:WPF: Why does DataTrigger delete my default style?WPF:为什么 DataTrigger 会删除我的默认样式?
【发布时间】:2017-06-13 21:44:06
【问题描述】:

刚刚学习 WPF,无法弄清楚这种行为。示例:

标签从窗口上的静态资源中获取其初始样式。那么,我有两种方法可以改变标签的样式:

  1. 使用按钮(通过 CodeBehind)
  2. 使用复选框(通过 DataTrigger 绑定)。

单击按钮后,我无法再通过 CheckBox 更改样式。 抱歉,我不明白为什么会这样。提前感谢任何可以帮助我的人:-) 这是代码:

XAML:

<Window x:Class="WtfDataTrigger.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:WtfDataTrigger"
        mc:Ignorable="d"
        Title="MainWindow" Height="350" Width="525">
    <Window.Resources>
        <Style TargetType="Label" x:Key="LabelStyle">
            <Setter Property="Foreground" Value="Red" />
        </Style>
    </Window.Resources>
    <StackPanel>
        <Label Name="Label1" Content="Label1" FontSize="24">
            <Label.Style>
                <Style TargetType="Label" BasedOn="{StaticResource LabelStyle}">
                    <Style.Triggers>
                        <DataTrigger Binding="{Binding ElementName=Checkbox, Path=IsChecked}" Value="True">
                            <Setter Property="Foreground" Value="Aqua" />
                        </DataTrigger>
                    </Style.Triggers>
                </Style>
            </Label.Style>
        </Label >
        <Button Content="Click Me to Change Label Style Using Routed Events" FontSize="18" Click="Button_Click" />
        <CheckBox Name="Checkbox" Content="Check Me to Change Label Style Using Data Trigger" FontSize="18">

        </CheckBox>

    </StackPanel>
</Window>

代码隐藏:

private void Button_Click(object sender, RoutedEventArgs e)
    {
        Label1.Foreground = new SolidColorBrush(Colors.DarkOrange);
    }

【问题讨论】:

    标签: xaml styles overriding datatrigger


    【解决方案1】:

    这是因为单击按钮时绑定丢失。直接更改在 XAML 中绑定的值后,新值将一起删除绑定。您可能需要另一个触发器并强制它发生。您可以编写代码来继续绑定或重新实例化原始绑定,但这有点矫枉过正。如果您要使用 XAML,我个人建议远离 Code behind... 我自己强迫自己永远不要编写 code behind,但这是一个设计选择,所以这是您选择做的事情。

    如果您必须使用后面的代码并且您确实希望主要坚持使用 XAML,那么您将需要构建使用 DependencyProperties 等的自定义控件,并像所有其他控件一样保持它们完全通用。

    这是题外话,但底线是您已通过单击按钮并直接设置 Foreground 属性来删除绑定。如果您必须使用后面的代码并希望保留绑定,我不介意发布代码来完成此操作,您可以选择同意或不同意,但这样设计有点让人头疼。

    【讨论】:

      猜你喜欢
      • 2018-04-04
      • 2014-04-15
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2015-02-28
      • 1970-01-01
      • 2019-06-13
      相关资源
      最近更新 更多