在WPF中实现数据验证,IDataErrorInfo 和 INotifyDataErrorInfo 是两种主流接口,它们都支持绑定层自动高亮错误、显示提示,但适用场景和能力有明显区别。
用 IDataErrorInfo 做基础同步验证
这是最轻量、兼容性最好的方式,适合简单表单、单字段即时校验(如非空、长度、格式)。它只提供“拉取式”错误信息——控件失去焦点或触发 Binding 更新时才调用,不主动通知变化。
在 ViewModel 中实现IDataErrorInfo接口,必须提供
this[string columnName]索引器和
string Error { get; } 属性(后者通常不用)
绑定时启用验证:Binding Path=Name, ValidatesOnDataErrors=True, NotifyOnValidationError=TrueWPF 自动将错误值传给
Validation.ErrorTemplate,配合
TextBox的
Style可自定义红框/提示图标 注意:索引器里不要 throw 异常,返回 null 或空字符串表示无错;返回非空字符串即为错误提示
用 INotifyDataErrorInfo 做动态异步验证
这是 WPF 4.5+ 推荐的现代方式,支持多错误、实时通知、异步校验(如用户名是否已存在),适合复杂业务场景。
实现INotifyDataErrorInfo接口,关键成员包括:
bool HasErrors、
IEnumerable GetErrors(string propertyName)、
event EventHandler<dataerrorschangedeventargs></dataerrorschangedeventargs>错误集合建议用
Dictionary<string list>></string>管理,每个属性可存多个错误消息 校验逻辑变更后,必须手动触发
ErrorsChanged事件(例如:
ErrorsChanged?.Invoke(this, new DataErrorsChangedEventArgs("Email")))
绑定写法类似:Binding Path=Email, ValidatesOnNotifyDataErrors=True, NotifyOnValidationError=True支持“清除所有错误”:清空字典后触发
ErrorsChanged并传入
null或空字符串
实际使用建议
多数项目推荐优先用 INotifyDataErrorInfo,尤其涉及服务端校验、多规则共存或 MVVM 框架(如 Prism、CommunityToolkit.Mvvm)集成时更自然。若需兼容 .NET Framework 4.0 或极简需求,IDataErrorInfo 仍可靠。
避免在GetErrors或索引器里做耗时操作(如网络请求),应提前完成并缓存结果 结合
INotifyPropertyChanged使用:属性变更 → 触发校验 → 更新错误集合 → 触发
ErrorsChangedUI 层可通过
Validation.HasError触发样式切换,或绑定
(Validation.Errors)[0].ErrorContent显示第一条提示 第三方库如 FluentValidation 可与两者桥接,提升规则复用性
基本上就这些。选哪个不取决于“高级与否”,而看是否需要实时响应、多错误叠加、异步支持——想清楚验证节奏和交互预期,接口就很容易落地。
