wpf IDataErrorInfo 验证

我可以给你一个简单的例子来说明如何在WPF中使用IDataErrorInfo接口来显示错误信息,并通过样式(Style)和触发器(Trigger)来在UI上反映这些错误。

首先,你需要一个实现了IDataErrorInfo接口的模型类。这个接口要求你实现两个方法:Error(通常用于整个对象的错误,但在这个例子中我们可能不会用到它)和this[string columnName](用于获取指定属性的错误信息)。

cs 复制代码
public class MyModel : IDataErrorInfo  
{  
    private string _propertyName;  
  
    public string PropertyName  
    {  
        get { return _propertyName; }  
        set  
        {  
            _propertyName = value;  
            // 这里可以添加属性更改通知,但在这个例子中我们省略它  
        }  
    }  
  
    public string Error => throw new NotImplementedException(); // 通常不实现,除非有全局错误  
  
    public string this[string columnName]  
    {  
        get  
        {  
            string error = string.Empty;  
            if (columnName == nameof(PropertyName))  
            {  
                if (string.IsNullOrEmpty(PropertyName))  
                {  
                    error = "PropertyName cannot be empty.";  
                }  
                // 可以添加更多验证逻辑  
            }  
            return error;  
        }  
    }  
}

然后,在XAML中,你需要为绑定到该模型的UI元素(如TextBox)设置一些样式和触发器,以便在验证失败时显示错误信息。但是,请注意,Validation.Errors集合本身并不直接支持数据绑定到UI元素(如TextBlock的Text属性)。相反,我们通常使用Validation.HasError附加属性来触发样式更改或显示错误模板。

以下是一个简单的XAML示例,展示了如何为TextBox设置样式,以便在验证失败时更改其边框颜色:

cs 复制代码
<Window x:Class="YourNamespace.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">  
    <Window.Resources>  
        <Style x:Key="ErrorTextBoxStyle" TargetType="TextBox">  
            <Setter Property="Validation.ErrorTemplate" Value="{x:Null}"/>  
            <Style.Triggers>  
                <Trigger Property="Validation.HasError" Value="True">  
                    <Setter Property="BorderBrush" Value="Red"/>  
                    <Setter Property="BorderThickness" Value="2"/>  
                    <Setter Property="ToolTip"  
                            Value="{Binding RelativeSource={RelativeSource Self},  
                                            Path=(Validation.Errors)[0].ErrorContent}"/>  
                </Trigger>  
            </Style.Triggers>  
        </Style>  
    </Window.Resources>  
  
    <Grid>  
        <TextBox Text="{Binding Path=PropertyName, ValidatesOnDataErrors=True, UpdateSourceTrigger=PropertyChanged}"  
                 Style="{StaticResource ErrorTextBoxStyle}"  
                 Margin="10"/>  
    </Grid>  
</Window>
相关推荐
月落.1 小时前
WPF的<ContentControl>控件
wpf
就是有点傻1 小时前
WPF中的依赖属性
开发语言·wpf
wangnaisheng1 小时前
【WPF】把一个Window放在左上角/右上角顶格显示
wpf
WineMonk2 小时前
.NET WPF CommunityToolkit.Mvvm框架
.net·wpf·mvvm
月落.2 小时前
WPF中的INotifyPropertyChanged接口
wpf
界面开发小八哥2 小时前
界面控件DevExpress WPF中文教程:Data Grid——卡片视图设置
.net·wpf·界面控件·devexpress·ui开发
平凡シンプル2 小时前
WPF 打包
wpf
VickyJames2 小时前
基于XAML框架和跨平台项目架构设计的深入技术分析
wpf·开源分享·unoplatform·winui3·项目架构
冷眼Σ(-᷅_-᷄๑)5 小时前
WPF缩放动画和平移动画叠加后会发生什么?
wpf·动画
△曉風殘月〆7 小时前
WPF MVVM入门系列教程(二、依赖属性)
c#·wpf·mvvm