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>
相关推荐
故渊at10 小时前
第二板块:Android 四大组件标准化学理 | 第十二篇:四大组件全景总结与系统服务(System Server)架构
android·架构·wpf·四大组件·system service
伶俜6614 小时前
# [特殊字符] 零基础学 ArkUI 数据持久化(专题三):5 种存储方案深度对比
学习·华为·wpf·harmonyos
IT策士14 小时前
Redis 从入门到精通:数据结构String 与键管理
数据结构·redis·wpf
AC赳赳老秦15 小时前
技术文章素材收集自动化:用 OpenClaw 自动爬取行业资讯、技术热点、优质文章
运维·开发语言·python·自动化·wpf·deepseek·openclaw
加号315 小时前
【WPF】 Storyboard 故事板动画设计深度解析
wpf
xiaoshuaishuai816 小时前
C# Avalonia 依赖属性与WPF的区别
开发语言·c#·wpf
大G的笔记本1 天前
生产级 Spring Boot 网关简单实现方案
wpf
稷下元歌3 天前
七天学会plc加机器视觉之AI 接入 外设模块开发全详细操作文档(全程配套视频按文档实操)
python·sql·qt·贪心算法·r语言·wpf·时序数据库
happyprince3 天前
11-Hugging Face Transformers 分布式与并行系统深度分析
分布式·c#·wpf
加号33 天前
【WPF】 基于 Canvas 读取并渲染 DXF 文件的技术指南
c#·wpf