WPF中的binding(十)- Binding数据的校验
来源:互联网 发布:软件著作权地域范围 编辑:程序博客网 时间:2024/05/20 09:06
Binding的ValidationRules属性的类型是Collection<ValidationRule>,从它的名称可以看见,每个 Binding可以接收多个校验条件,每个条件都是ValidationRule对象。
一、校验外部方法的更新操作
界面上放置一个TextBox和一个Slider,我们要对TextBox的输入值进行校验。首先需要准备一个ValidationRule派生类:
可以看到,在该派生类中,我们需要实现Validate方法,该方法的返回值类型为ValidationResult,如果校验成功,ValidationResult的IsVaild的属性会被置为True;如果校验失败,ValidationResult的IsVaild的属性会被置为False,并为其ErrorContent属性设置一个合适的消息的内容。
然后,我们在后台建立Binding:
运行效果如下,当我们输入不在[0,100]范围内的数字时,textBox1会出现红色的边缘,表示校验错误。
三、校验失败的信息显示
当校验失败时,Validate 返回的ValidationResult携带了一条错误信息,我们怎么在界面上显示这个错误信息呢?
首先,需要把Binding对象的NotifyOnValidationError置为true。这样当数据校验失败时,Binding就会发出一个信息,以Binding对象的Target为起点,沿着UI元素树向上传播。信号每到达一个节点,如果节点设置了对这个信号的侦听器(事件处理器),那么这个侦听器就会被触发处理这个信号。
接下来,我们就创建这样一个事件处理器:
运行效果如下,可以看到错误信息已经显示到了textBox1的ToolTip上:
一、校验外部方法的更新操作
首先,新建一个WPF项目,Xmal文件的代码如下:
<Window x:Class="_6_31.MainWindow" xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation" xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml" Title="MainWindow" Height="350" Width="525"> <Grid> <TextBox Height="23" HorizontalAlignment="Left" Margin="52,66,0,0" Name="textBox1" VerticalAlignment="Top" Width="409" /> <Slider Height="23" HorizontalAlignment="Left" Margin="52,150,0,0" Name="slider1" VerticalAlignment="Top" Width="409" /> </Grid></Window>
界面上放置一个TextBox和一个Slider,我们要对TextBox的输入值进行校验。首先需要准备一个ValidationRule派生类:
public class RangeValidationRule : ValidationRule { //需¨¨要°a实º¦Ì现?Validate方¤?法¤¡§ public override ValidationResult Validate(object value, System.Globalization.CultureInfo cultureInfo) { double d = 0; if (double.TryParse(value.ToString(), out d) == true) { if (d >= 0 && d <= 100) { return new ValidationResult(true, null); } } return new ValidationResult(false,"Validation Error"); } }
可以看到,在该派生类中,我们需要实现Validate方法,该方法的返回值类型为ValidationResult,如果校验成功,ValidationResult的IsVaild的属性会被置为True;如果校验失败,ValidationResult的IsVaild的属性会被置为False,并为其ErrorContent属性设置一个合适的消息的内容。
然后,我们在后台建立Binding:
public MainWindow() { InitializeComponent(); Binding binding = new Binding("Value") { Source = this.slider1 }; binding.UpdateSourceTrigger = UpdateSourceTrigger.PropertyChanged; RangeValidationRule rule = new RangeValidationRule(); binding.ValidationRules.Add(rule); this.textBox1.SetBinding(TextBox.TextProperty, binding); }
运行效果如下,当我们输入不在[0,100]范围内的数字时,textBox1会出现红色的边缘,表示校验错误。
二、校验Source的数据
接下来,我们将slider1的取值范围调成-20~120,发现将其调到超过0~100的范围时,textBox1反而没有进行校验。
这是因为上面我们设置的校验只在用户对Binding目标(textBox1)输入时进行校验,而对Binding的Source(slider1)传过来的数据不会进行校验。如果想要设置同时校验Source数据,我们需要将校验规则的ValidatesOnTargetUpdated设置为True。构造代码如下:
public MainWindow() { InitializeComponent(); Binding binding = new Binding("Value") { Source = this.slider1 }; binding.UpdateSourceTrigger = UpdateSourceTrigger.PropertyChanged; RangeValidationRule rule = new RangeValidationRule(); rule.ValidatesOnTargetUpdated = true; binding.ValidationRules.Add(rule); this.textBox1.SetBinding(TextBox.TextProperty, binding); }
实现效果如下:
三、校验失败的信息显示
当校验失败时,Validate 返回的ValidationResult携带了一条错误信息,我们怎么在界面上显示这个错误信息呢?
首先,需要把Binding对象的NotifyOnValidationError置为true。这样当数据校验失败时,Binding就会发出一个信息,以Binding对象的Target为起点,沿着UI元素树向上传播。信号每到达一个节点,如果节点设置了对这个信号的侦听器(事件处理器),那么这个侦听器就会被触发处理这个信号。
public MainWindow() { InitializeComponent(); Binding binding = new Binding("Value") { Source = this.slider1 }; binding.UpdateSourceTrigger = UpdateSourceTrigger.PropertyChanged; RangeValidationRule rule = new RangeValidationRule(); rule.ValidatesOnTargetUpdated = true; binding.ValidationRules.Add(rule); binding.NotifyOnValidationError = true; this.textBox1.SetBinding(TextBox.TextProperty, binding); }
接下来,我们就创建这样一个事件处理器:
public MainWindow() { InitializeComponent(); Binding binding = new Binding("Value") { Source = this.slider1 }; binding.UpdateSourceTrigger = UpdateSourceTrigger.PropertyChanged; RangeValidationRule rule = new RangeValidationRule(); rule.ValidatesOnTargetUpdated = true; binding.ValidationRules.Add(rule); //设¦¨¨置?NotifyOnValidationError=true,ê?一°?旦Ì?校¡ê验¨¦失º¡ì败㨹就¨ª触䣤发¤¡é信?号? binding.NotifyOnValidationError = true; this.textBox1.SetBinding(TextBox.TextProperty, binding); //关?联¢a校¡ê验¨¦失º¡ì败㨹的Ì?事º?件t处ä|理¤¨ª器¡Â this.textBox1.AddHandler(Validation.ErrorEvent,new RoutedEventHandler(this.ValidationError)); } void ValidationError(object sender, RoutedEventArgs e) { if (Validation.GetErrors(this.textBox1).Count > 0) { this.textBox1.ToolTip = Validation.GetErrors(this.textBox1)[0].ErrorContent.ToString(); } }
运行效果如下,可以看到错误信息已经显示到了textBox1的ToolTip上:
0 0
- WPF中的binding(十)- Binding数据的校验
- WPF中的binding(十一)- Binding数据的转换
- WPF使用Binding对数据的校验
- WPF中的binding(九)- 使用Binding的RelativeSource
- WPF中的binding(六)- 使用XML数据作为Binding的源
- WPF中的binding(十二)- 多路Binding
- WPF Data Binding之数据的转换和校验【四】
- Binding对数据的校验
- Binding数据校验
- 数据绑定(九)Binding的数据校验
- WPF中的Binding
- WPF中的Binding(一)
- WPF中的Binding
- WPF中的binding
- WPF中的binding(二)- 使用CLR对象或者对象名称作为Binding的数据源
- WPF中的binding(三)- 使用DataContext作为Binding的数据源
- WPF中的binding(五)- 使用DataTable作为Binding的源
- WPF中的binding(七)- 使用LINQ检索作为Binding的数据源
- osgi + felix example2b编写
- PHP几个防SQL注入攻击自带函数区别
- vijos1022(强联通分量模版题)
- C#基础一
- JavaWeb--Struts2——OGNL表达式
- WPF中的binding(十)- Binding数据的校验
- VMware 12安装Mac OS X 10.11
- spiral-matrix-ii
- 1005
- 解决Yum安装依赖问题
- JavaWeb系列——Hibernate——延迟加载(转)
- Linux中常用的查看系统信息的命令
- jquery、js调用iframe父窗口与子窗口元素的方法整理
- 总结四