UWP样式触发器丢失

时间:2015-11-11 10:18:58

标签: c# xaml visual-studio-2015 win-universal-app uwp

似乎UWP XAML不支持样式中的触发器。完成触发器的常见解决方法是什么?

<Style TargetType="Button">
    <Style.Triggers>
        <Trigger Property="Visibility" Value="Collapsed">
            <Setter Property="Text" Value="" />
        </Trigger>
    </Style.Triggers>
</Style>

目前我在UWP中看到以下选项来完成触发器:

使用动画或VisualStateTriggers。如果我使用它们不将控件调整到屏幕,那么两者似乎都是错误的。

我认为我找到了一般为控件实现触发器的正确​​方法。 请参阅以下代码作为演示:

xmlns:Interactivity="using:Microsoft.Xaml.Interactivity" 
xmlns:Core="using:Microsoft.Xaml.Interactions.Core"

<Border x:Name="BackgroundElement" Tag="Text">
    <Interactivity:Interaction.Behaviors>
        <Core:DataTriggerBehavior Binding="{Binding Tag, ElementName=BackgroundElement}" Value="Text">
            <Core:ChangePropertyAction PropertyName="BorderBrush" Value="AliceBlue" />
        </Core:DataTriggerBehavior>
    </Interactivity:Interaction.Behaviors>
</Border>

如果没有ElementName的解决方案,那将是非常棒的。我会在WPF中使用AncestorType完成此操作,但在UWP中也缺少这一点。无论如何,似乎你不能在样式中使用Core:DataTriggerBehavior

1 个答案:

答案 0 :(得分:6)

在WinRT中,RelativeSourceMode仅支持自我 TemplatedParent 模式, FindAncestor 不可用。因此,当您使用XAML Behaviors时,需要使用ElementName作为解决方法。如果您在项目中使用DataContext或ViewModel,则可以绑定到DataContext或ViewModel以避免使用ElementName。例如:

<Page ...>
    <Page.Resources>
        <local:MyViewModel x:Key="ViewModel" />
    </Page.Resources>
    ...
    <Border x:Name="BackgroundElement" DataContext="{Binding Source={StaticResource ViewModel}}">
        <Interactivity:Interaction.Behaviors>
            <Core:DataTriggerBehavior Binding="{Binding Tag}" Value="Text">
                <Core:ChangePropertyAction PropertyName="Background" Value="Red" />
            </Core:DataTriggerBehavior>
        </Interactivity:Interaction.Behaviors>
    </Border>
    ...
</Page>

上面使用的ViewModel:

public class MyViewModel : INotifyPropertyChanged
{
    public event PropertyChangedEventHandler PropertyChanged;

    private string _tag;

    public string Tag
    {
        get
        {
            return _tag;
        }

        set
        {
            _tag = value;
            if (PropertyChanged != null)
            {
                PropertyChanged(this, new PropertyChangedEventArgs("Tag"));
            }
        }
    }
}