Datagrid.Validating.Data(验证)

6 篇文章 0 订阅
5 篇文章 0 订阅

验证说起来也不复杂,在对应的列中添加<xcdg:Column.DisplayMemberBindingInfo><xcdg:DataGridBindingInfo Path="和列名中的fileName一样"><xcdg:DataGridBindingInfo.ValidationRules><local:YearValidationRule /></xcdg:DataGridBindingInfo.ValidationRules></xcdg:DataGridBindingInfo> </xcdg:Column.DisplayMemberBindingInfo>这样的属性并在YearValidationRule中写相应的验证代码即可。本例中加入了验证改变背景色代码。

<Window x:Class="Datagrid.Validating.Data.MainWindow"
        xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
        xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
        xmlns:local ="clr-namespace:Datagrid.Validating.Data"
        Title="MainWindow" Height="350" Width="525" xmlns:xcdg="http://schemas.xceed.com/wpf/xaml/datagrid">
    <Window.Resources>
        <xcdg:DataGridCollectionViewSource x:Key="cvs_composers"
                                        Source="{Binding Source={x:Static Application.Current}, 
                                                         Path=PersonList}"/>
        <Style x:Key="cell_error" TargetType="{x:Type xcdg:DataCell}">
            <!--<Setter Property="Foreground" Value="Red"/>-->
            <Setter Property="Background" Value="#FFCC00"/>
            <Setter Property="ToolTip" Value="Invalid value"/>
        </Style>

    </Window.Resources>
    <Grid>
        <xcdg:DataGridControl ItemsSource="{Binding Source={StaticResource cvs_composers}}"
                        UpdateSourceTrigger="RowEndingEdit">
            <xcdg:DataGridControl.Columns>
                <xcdg:Column FieldName="BirDay" CellErrorStyle="{StaticResource cell_error}">
                    <xcdg:Column.DisplayMemberBindingInfo>
                        <xcdg:DataGridBindingInfo Path="BirDay">
                            <xcdg:DataGridBindingInfo.ValidationRules>
                                <local:YearValidationRule />
                            </xcdg:DataGridBindingInfo.ValidationRules>
                        </xcdg:DataGridBindingInfo>
                    </xcdg:Column.DisplayMemberBindingInfo>
                </xcdg:Column>
                <xcdg:Column FieldName="OldDay">
                    <xcdg:Column.DisplayMemberBindingInfo>
                        <xcdg:DataGridBindingInfo Path="OldDay">
                            <xcdg:DataGridBindingInfo.ValidationRules>
                                <local:YearValidationRule />
                            </xcdg:DataGridBindingInfo.ValidationRules>
                        </xcdg:DataGridBindingInfo>
                    </xcdg:Column.DisplayMemberBindingInfo>
                </xcdg:Column>
            </xcdg:DataGridControl.Columns>
        </xcdg:DataGridControl>
    </Grid>
</Window>


 

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Windows.Controls;
using System.Globalization;
namespace Datagrid.Validating.Data
{
    class YearValidationRule : ValidationRule
    {
        public override ValidationResult Validate(object value, CultureInfo cultureInfo)
        {
            int year = (int)value;
            if (year > DateTime.Now.Year)
                return new ValidationResult(false, "Chosen year cannot be greater than this year.");
            return ValidationResult.ValidResult;
        }
    }
}


 

WPF DataGrid是一种用于显示数据的控件,而DataGrid.Columns则是DataGrid中的列集合。你可以通过设置DataGrid.Columns的Background属性来改变整个列的背景颜色。 在WPF中,你可以使用多种方式来设置DataGrid.Columns的Background属性,包括使用静态资源、绑定属性、使用样式等。以下是一些示例代码: 1. 使用静态资源设置DataGrid.Columns的Background属性: ``` <DataGrid> <DataGrid.Columns> <DataGridTextColumn Header="Column 1" Binding="{Binding Column1}"> <DataGridTextColumn.HeaderStyle> <Style TargetType="DataGridColumnHeader"> <Setter Property="Background" Value="{StaticResource MyBrush}" /> </Style> </DataGridTextColumn.HeaderStyle> </DataGridTextColumn> </DataGrid.Columns> </DataGrid> ``` 2. 使用绑定属性设置DataGrid.Columns的Background属性: ``` <DataGrid> <DataGrid.Columns> <DataGridTextColumn Header="Column 1" Binding="{Binding Column1}"> <DataGridTextColumn.HeaderStyle> <Style TargetType="DataGridColumnHeader"> <Setter Property="Background" Value="{Binding DataContext.Column1HeaderBackground, RelativeSource={RelativeSource AncestorType={x:Type DataGrid}}}" /> </Style> </DataGridTextColumn.HeaderStyle> </DataGridTextColumn> </DataGrid.Columns> </DataGrid> ``` 3. 使用样式设置DataGrid.Columns的Background属性: ``` <DataGrid> <DataGrid.Resources> <Style TargetType="DataGridColumnHeader"> <Setter Property="Background" Value="LightGray" /> </Style> </DataGrid.Resources> <DataGrid.Columns> <DataGridTextColumn Header="Column 1" Binding="{Binding Column1}" /> </DataGrid.Columns> </DataGrid> ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值