“使用IsMouseOver更改标签内容”复选框

本文关键字:复选框 标签 使用 IsMouseOver | 更新日期: 2023-09-27 17:50:37

Hei,

我正在创建一个按钮,上面有一个复选框。现在,当用户用鼠标悬停在复选框上时,我想更改按钮上的文本。

这是我目前拥有的:

    <Button Grid.Row="1" Margin="0,0,136,12" Name="btnRefresh" Height="28" VerticalAlignment="Bottom" HorizontalAlignment="Right" Width="120" Click="btnRefresh_Click">
        <Grid Width="111">
            <CheckBox  Height="16" HorizontalAlignment="Left" Margin="0,2,0,0" Name="cbAutoRefresh" VerticalContentAlignment="Center">
                <CheckBox.Style>
                    <Style TargetType="{x:Type CheckBox}">
                        <Style.Triggers>
                            <Trigger Property="IsMouseOver" Value="True">
                                <Setter Property="Content" Value="Auto Refresh" />
                            </Trigger>
                        </Style.Triggers>
                    </Style>
                </CheckBox.Style>
            </CheckBox>
            <Label Name="btnLabel" Margin="32,-4,25,-4">Refresh</Label>
        </Grid>
    </Button>

但是像这样它会更改复选框的内容,我如何更改btnLabel的内容?

“使用IsMouseOver更改标签内容”复选框

当前您只是在修改组合框的样式,这就是为什么触发器只是更改组合框的内容。

要监听触发器中的其他控件属性,可以使用Databinding,如下所示:

<Label Name="btnLabel" Margin="32,-4,25,-4">
    <Label.Style>
        <Style>
            <Style.Triggers>
                <DataTrigger Binding="{Binding ElementName=comboBoxName, Path=IsMouseOver}" Value="False"
                     <Setter Property="Content" Value="Refresh"/>
                </DataTrigger>
                <DataTrigger Binding="{Binding ElementName=comboBoxName, Path=IsMouseOver}" Value="True"
                     <Setter Property="Content" Value="Auto Refresh"/>
                </DataTrigger>
            </Style.Triggers>
        </Style>
    </Label.Style>
</Label>