当按钮有焦点时,更改网格的可见性

本文关键字:网格 可见性 按钮 焦点 | 更新日期: 2023-09-27 18:16:06

我正在一个WPF应用程序上工作,我想改变一个网格的可见性,如果只有当一个按钮有焦点。我有下面的代码来改变按钮的背景,如果它有焦点。我知道如何以编程方式做到这一点,但我想知道如何在XAML中完成同样的事情。

        <Style TargetType="{x:Type Button}">
            <Style.Triggers>
                <Trigger Property="IsFocused" Value="True">
                    <Setter Property="Background" Value="Aqua" />
                </Trigger>
            </Style.Triggers>
        </Style>

当按钮有焦点时,更改网格的可见性

你可以给你的按钮命名并使用一个DataTrigger:

<Window 
    ...    
    >
    <Window.Resources>
        <Style TargetType="{x:Type Grid}">
            <Style.Triggers>
                <DataTrigger Binding="{Binding IsFocused, ElementName=butt}" Value="True">
                    <Setter Property="Visibility" Value="Collapsed" />
                </DataTrigger>
            </Style.Triggers>
        </Style>
    </Window.Resources>
    <StackPanel>
        <Button x:Name="butt">Hide</Button>
        <Grid>
            <Label Background="Yellow">Inside Grid</Label>
        </Grid>
        <Button>Steal focus</Button>
    </StackPanel>
</Window>

编辑

<Window 
    ...    
    >
    <Window.Resources>
        <Style x:Key="CollapsedGridStyle" TargetType="{x:Type Grid}">
            <Style.Triggers>
                <DataTrigger Binding="{Binding IsChecked, ElementName=butt}" Value="True">
                    <Setter Property="Visibility" Value="Collapsed" />
                </DataTrigger>
            </Style.Triggers>
        </Style>
    </Window.Resources>
    <StackPanel>
        <ToggleButton x:Name="butt">Hide</ToggleButton>
        <Grid x:Name="GridA"
              Style="{StaticResource CollapsedGridStyle}">
            <Label Background="Yellow">Grid A</Label>
        </Grid>
        <Grid x:Name="GridB">
            <Label Background="Green">Grid B</Label>
        </Grid>
    </StackPanel>
</Window>