Silverlight之DescriptionViewer

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

Silverlight之DescriptionViewer_第1张图片

可以看到在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只会则会显示描述信息。

你可能感兴趣的:(silverlight)