Silverlight 2支持基本的数据验证功能。在Silverlight 2中,当我们把数据绑定到某个UI控件的时 候,该数据所具有的有效性规则也自动被绑定到了该UI控件上。
比如某个数据字段被设置为整数型,当我们用非整数型数据对该字段进行更新的时候就会发生错误。 我们就可以利用这个规则在UI中对输入数据进行验证。要做到这点,我们只要设置两个XAML属性,并在所 定义的事件中实现我们所期望的UI行为就可以了。
比如下面的XAML代码定义了一组控件,用户通过TextBox对数据进行更新:
﹤StackPanel x:Name="dataForm"﹥
﹤TextBlock Text="FirstName" Width="125" FontSize="12" /﹥
﹤TextBox x:Name="FirstNameTextBox" IsReadOnly="False" Width="150"
Text="{Binding FirstName, Mode=TwoWay, NotifyOnValidationError=true, ValidatesOnExceptions=true}"
BindingValidationError="FirstNameTextBox_BindingValidationEr ror"/﹥
﹤/StackPanel﹥
当NotifyOnValidationError和ValidatesOnExceptions这两个属性都设置为true的时候,Silverlight 就会在对输入数据验证所绑定的规则发生错误的时候触发BindingValidationError事件,这样我们就会在 验证发生错误时得到通知。
接下来我们要做的就是实现事件触发时的行为,也就是我们期望的UI行为。如:
private void FirstNameTextBox_BindingValidationError(object sender, ValidationErrorEventArgs e)
{
if (e.Action == ValidationErrorEventAction.Added)
{
((Control)e.OriginalSource).Background = new SolidColorBrush(Colors.Red);
this.Dispatcher.BeginInvoke(() =>HtmlPage.Window.Alert("The input format is invalid"));
}
if (e.Action == ValidationErrorEventAction.Removed)
{
((Control) e.OriginalSource).Background = new SolidColorBrush(Colors.White);
}
}
在上面这段代码中,当错误发生时,控件(这里是TextBox)的背景色就会变成红色,并利用HTML页面 的警告窗口给用户提示信息。而当错误被更正时,空间就会还原到默认的白色。