zoukankan      html  css  js  c++  java
  • 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>
  • 相关阅读:
    C#调用webservice 时如何传递实体对象
    Gridview实现突出显示某一单元格的方法
    oracle数据库存储过程分页
    GridView合并表头多重表头
    Gridview中实现求和统计功能
    C#封装的一个JSON操作类
    C#通过StreamWriter对象实现把数值内容写到记事本
    Android CTS
    离线安装eclipse maven插件
    selenium2 页面对象模型Page Object
  • 原文地址:https://www.cnblogs.com/lgmbk/p/5087231.html
Copyright © 2011-2022 走看看