如何利用 IDataErrorInfo 实现数据校验
一、定义:
ValidatesOnDataErrors 是一种在 WPF 中实现数据校验的方式,可以通过在 XAML 中设置属性 ValidatesOnDataErrors 为 True 来启用。
二、使用:
① 在 ViewModel 中实现 IDataErrorInfo 接口,该接口定义了两个属性:Error 和 Item[string columnName]
—— Error 属性返回 ViewModel 中所有错误的描述信息;
—— Item[string columnName] 属性返回指定属性的错误描述信息。
② 在 XAML 中设置 Binding 的 ValidatesOnDataErrors 属性为 True,例如:
<TextBox Text="{Binding Name, ValidatesOnDataErrors=True}" />
③ 在 ViewModel 中对需要校验的属性设置注解,例如:
public class Person : IDataErrorInfo { public string Name { get; set; } public int Age { get; set; } public string this[string columnName] { get { string error = null; switch (columnName) { case "Name": if (string.IsNullOrEmpty(Name)) error = "Name不能为空"; break; case "Age": if (Age < 0 || Age > 120) error = "Age必须在0到120之间"; break; } return error; } } public string Error { get { return null; } } }
在this[string columnName]方法中,我们可以根据传入的列名判断该列的值是否合法:
—— 如果不合法则返回对应的错误信息。
—— 如果返回 null 或者空字符串,则表示该属性的值是有效的。
Error方法:我们可以判断整个数据模型的值是否合法,如果不合法则返回对应的错误信息.
注意:
如果在this[string columnName]方法中返回了错误信息,则Error方法不会被调用。
只有当所有属性的值都合法时,Error方法才会被调用。
因此,在实现IDataErrorInfo接口时,我们需要在this[string columnName]方法中尽可能地判断属性的值是否合法,以减少Error方法的调用次数。
④ 在界面上输入数据时,如果校验失败,会在控件旁边显示红色感叹号图标,鼠标悬浮在图标上可显示错误信息。