Silverlight之DescriptionViewer

可能看到这个标题,不太理解是什么,这个就是一个控件,先看下效果:

可以看到在TextBox的左边一个叹号的符号,当悬浮上之后显示当前TextBox的描述。

其实这个很简单,这里也要提到Silverlight之Validate文中已经使用过的Display特性了:

看下例子:

 private string productName;
[Required(ErrorMessage="必须输入ProdctName")]
[Display(Name = "Product Name", Description = "This is the retail product name.")]
public string ProductName
{
get { return productName; }
set {
ValidationContext context = new ValidationContext(this, null, null);
context.MemberName = "ProductName";
Validator.ValidateProperty(value, context);
productName = value;
OnPropertyChanged(new PropertyChangedEventArgs("ProductName"));
}
}



在Display特性中指定了Name属性和Description属性,那这两个分别是什么作用呢,看下边代码:

  <sdk:Label Target="{Binding ElementName=txtName}" Grid.Column="0"/>
<TextBox x:Name="txtName" Grid.Column="1" Margin="0 5" Text="{Binding ProductName,Mode=TwoWay, ValidatesOnExceptions=True, NotifyOnValidationError=True}"></TextBox>
<sdk:DescriptionViewer Grid.Column="2" Target="{Binding ElementName=txtName}"></sdk:DescriptionViewer>

 

可能有童鞋会疑惑,为什么在Label中木有指定Context属性,反而是指定了Target为当前的TextBox的Name值,没错这个就是重点,因为我们给ProductName指定了

Display的属性,同时当前的TextBox的Binding的属性就是ProductName,那么当指定一个Element的Target为其只会则会在Element的内容中显示Display的Name值,

也就是说,当这么做只会Label的值就是Display的Name属性的值。

那么Description的作用呢,可以看到代码中使用了DescriptionViewer控件,没错这个就是专门用来显示描述的控件,同理指定其的Target为TextBox的Name,那么当

指定了属性的Display只会则会显示描述信息。

转载于:https://www.cnblogs.com/ListenFly/archive/2012/01/03/2310995.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值