Silverlight之我见——数据批示(2)

 接着上一回的话题,继续来研究数据批示特性,先拿简单的RageAttribute来弄弄,接着上次的示例,添加一个Age属性,并加上RangeAttribute。

  1. [Range(20,60,ErrorMessage="年龄范围在20与60之间。")]  
  2. [Display(Name="年龄",Description="歌手年龄。")]  
  3. public int Age { get; set; }   


接着把XAML也补完整。

 

  1. <sdk:Label x:Name="lbAge" Target="{Binding ElementName=txtAge}" Grid.Column="0"  
  2.          Grid.Row="2" FontSize="14" Margin="1,1,20,1"/>  
  3. <StackPanel Grid.Column="1" Grid.Row="2" Orientation="Horizontal">  
  4.     <TextBox x:Name="txtAge" Margin="1,1" Width="165"  
  5.              Text="{Binding Age}"/>  
  6.     <sdk:DescriptionViewer Target="{Binding ElementName=txtAge}"/>  
  7. </StackPanel>  


 

是不是可以了呢?
运行一下,定义的范围在20-60,现在输入100,然后把焦点文本框移走,结果发现,没有发生验证。
 
好,简单的不行,继续探索,把属性的定义改成这样:
  1. int m_Age = 20;  
  2. [Range(20, 60, ErrorMessage = "年龄范围在20与60之间。")]  
  3. [Display(Name = "年龄", Description = "歌手年龄。")]  
  4. public int Age  
  5. {  
  6.     get { return this.m_Age; }  
  7.     set  
  8.     {  
  9.         Validator.ValidateProperty(value,  
  10.             new ValidationContext(this, null, null) { MemberName = "Age" });  
  11.         this.m_Age = value;  
  12.     }  
  13. }  


 

然后再次运行,哟,上帝!还是不行,怎么了?Validator的验证方法也调用了,为什么还不行呢?
不要气馁,继续,还记得在XAML中写的绑定扩展标记不?想起来了吗?
1、默认是单向绑定Mode = Oneway;
2、没有显式设置启用验证。
嗯,这下明白了,再改改
 
  1. <TextBox x:Name="txtAge" Margin="1,1" Width="165"  
  2.                      Text="{Binding Age,Mode=TwoWay,ValidatesOnExceptions=true, NotifyOnValidationError=true}"/>  

再运行,这回验证了,但是,抛出了异常。那有没有办法不抛出异常而显示友好的错误提示呢?答案当然有,使用ValidationSummary 。
  1. <sdk:ValidationSummary Grid.Row="3" Grid.ColumnSpan="2"/>   

再次按下F5,验证失败后仍然抛出异常,这时候,你可能有些失望。

山重水复疑无路,柳暗花明会成功,这时候,你在项目上右击,选择“在浏览器中查看”,啊,眼前一亮,出来了。

 

现在,总结一下方法:

1、在定义公共属性时加上对应的特性,如RangeAttribute;

2、在属性的set访问器上调用Validator的ValidateProperty方法;

3、在XAML或前台绑定时,将Binding 的Mode设置为TwoWay,ValidatesOnExceptions和NotifyOnValidationError设置为True;

4、添加ValidationSummary控件以显示错误列表,当然,不加也可以,看看下面的截图。

 

 

5、在非debug模式下运行程序。

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值