WPF驗證技巧講解
WPF驗證的實現方式比較靈活,對于初學者來說掌握起來并不是非常的輕松。我們在這里為大家詳細介紹了具體的操作方法,希望對大家有所幫助。#t#
一.兩步實現WPF驗證
(1)實現INotifyPropertyChanged接口,并為驗證的屬性添加需要驗證的元數據
- [StringLengthValidator(1, 10,
MessageTemplate = "First Name
must be between 1 and 15 characters")] - public string FirstName
- {
- get { return this.firstName; }
- set
- {
- this.firstName = value;
- this.OnPropertyChanged("FirstName");
- }
- }
(2)在前端使用Validizor控件,為后端驗證顯示錯誤
- < Validizor Source="
{Binding FirstName}"/>- < TextBox Text="{Binding
FirstName,UpdateSource
Trigger=PropertyChanged}"/>
WPF驗證二.使用EnterpriseLibrary驗證組
(1)指定元數據Ruleset屬性
- [StringLengthValidator(1, 20,
MessageTemplate = "Last Name
must be between 1 and 20
characters", Ruleset = "Default")]- public string LastName
- {
- get { return this.lastName; }
- set
- {
- this.lastName = value;
- this.OnPropertyChanged("LastName");
- }
- }
(2)前端控件同時指定Ruleset屬性
- < Validizor Source=
"{Binding LastName}"
Ruleset="Default">
三.內置WPF驗證的缺陷
(1)ui錯誤無法變更,驗證的不僅僅只是TextBox(3.5 sp1 可以把錯誤信息轉嫁)
wpf內置驗證的做法,自定義ValidationRule
(2)若使用了內置驗證做法,控件的驗證將會失效
四.兩個屬性以上的WPF驗證
(1)單一的元數據標簽無法做到,需要寫額外的方法進行驗證
(2)使用HasSelfValidation元數據標簽驗證對象
- [HasSelfValidation]
- public class Person2 :
INotifyPropertyChanged- {
- }
(3)添加驗證方法
- [SelfValidation(Ruleset
= "Default")]- public void ValidateDefault
(ValidationResults results)- {
- }
(4)針對特定屬性來驗證
(4)-1 實行IPropertyChangedName接口,根據進來的屬性進行判斷,可以填寫多個方法用于區分
- [SelfValidation(Ruleset =
"Default")]- public void ValidateDefault
(ValidationResults results)- {
- switch (this.PropertyChangedName)
- {
- case "FirstName":
- break;
- }
- }
- [SelfValidation(Ruleset =
"Default")]- public void ValidateDefault
(ValidationResults results)- {
- switch (this.PropertyChangedName)
- {
- case "LastName":
- break;
- }
- }
(5)前端控件指定