在Xaml中单击时如何更改按钮内容
本文关键字:何更改 按钮 Xaml 单击 | 更新日期: 2023-09-27 18:21:31
我有一个名为Hold button的按钮内容。当我单击按钮时,按钮内容应更改为"继续",如果再次按下"继续"按钮,则表示"保持"应可见。
XAML代码:
<Button Style="{StaticResource CommonButtonStyle}" Template="{DynamicResource GlassButton}" ToolTip="F9" Click="Hold_Click" PreviewKeyDown="Hold_PreviewKeyDown" Name="OK" Margin="1,49,25,0" Grid.Column="2" Grid.Row="13" Grid.RowSpan="2">
<StackPanel Style="{StaticResource ButtonStackPanel}">
<Image Style="{StaticResource CancelImages}" />
<TextBlock Text="{Loc lblHold}" Style="{StaticResource ButtonTextBlock}" />
</StackPanel>
</Button>
您可以在按钮的Click
事件中尝试类似的操作:
private void holdResumeButton_Click(object sender, RoutedEventArgs e)
{
if ((string)holdResumeButton.Content == "Hold")
holdResumeButton.Content = "Resume";
else
holdResumeButton.Content = "Hold";
}
XAML:
<Button x:Name="holdResumeButton"
Content="Hold"
Click="holdResumeButton_Click"/>
使用ToggleButton
:
<Style x:Key="HoldOrResumeButton" TargetType="{x:Type ToggleButton}" BasedOn="{StaticResource {x:Type ToggleButton}}">
<Setter Property="Content">
<Setter.Value>
<TextBlock Text="Hold"/>
</Setter.Value>
</Setter>
<Style.Triggers>
<DataTrigger Binding="{Binding IsChecked, RelativeSource={RelativeSource Mode=Self}}" Value="True">
<Setter Property="Content">
<Setter.Value>
<TextBlock Text="Resume"/>
</Setter.Value>
</Setter>
</DataTrigger>
</Style.Triggers>
</Style>
也许您可以使用ToggleButton
而不是Button
,这样您就可以绑定到IsChecked
属性。http://msdn.microsoft.com/en-us/library/system.windows.controls.primitives.togglebutton.ischecked.aspx
例如:
<ToggleButton x:Name="TB">
<ToggleButton.Style>
<Style>
<Style.Triggers>
<Trigger Property="ToggleButton.IsChecked" Value="True">
<Setter Property="ToggleButton.Content" Value="Resume"></Setter>
</Trigger>
</Style.Triggers>
</Style>
</ToggleButton.Style>
</ToggleButton>