原文:
WPF用样式实现TextBox的虚拟提示效果
【版权声明】本文为博主原创,未经允许禁止用作商业用途,如有转载请注明出处。
话说好多软件和网站都能实现虚拟提示,好吧这个名词是我自己起的,因为我也不知道这么形容这个效果。
效果描述:在TextBox没有输入值之前显示灰色提示信息,当获得焦点时提示自动消失,如果没有编辑离开此控件则依然显示提示信息,直到输入值为止。
效果图:
这里我用到了一个属性Tag用来存储提示信息,各位也可以根据实际情况绑定不同的属性或数据源。主要是通过样式中的MultiTrigger和控件的ControlTemplate来实现的。
代码比较简单,如有疑问可以随时联系我。
代码如下:
1 <Style TargetType="{x:Type TextBox}"> 2 <Style.Triggers> 3 <MultiTrigger> 4 <MultiTrigger.Conditions> 5 <Condition Property="Text" Value=""/> 6 <Condition Property="TextBox.IsFocused" Value="false"/> 7 </MultiTrigger.Conditions> 8 <Setter Property="Template"> 9 <Setter.Value> 10 <ControlTemplate> 11 <Border BorderThickness="1" BorderBrush="Gray" Margin="0"> 12 <TextBlock x:Name="MainTextBlock" Text="{TemplateBinding TextBox.Tag}" Width="{TemplateBinding TextBox.ActualWidth}" Foreground="Gray" VerticalAlignment="Center" HorizontalAlignment="Left"/> 13 </Border> 14 </ControlTemplate> 15 </Setter.Value> 16 </Setter> 17 </MultiTrigger> 18 </Style.Triggers> 19 </Style>