wpf datagrdie中的非数字验证

xaml 中的代码部分分为头部的错误界面和下侧的展示界面

<Window x:Class="UserDemo3.MainWindow"
        xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
        xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
        Title="MainWindow" Height="433" Width="545">
    <Grid>
        <DataGrid Name="dGrid" Margin="5,8,5,51" CanUserAddRows="False"  CanUserDeleteRows="True" ItemsSource="{Binding}"    IsReadOnly="False" CellEditEnding="dGrid_CellEditEnding">
            <DataGrid.Resources>
                <Style x:Key="errorStyle" TargetType="{x:Type TextBox}">
                    <Setter Property="Padding" Value="-2"/>
                    <Style.Triggers>
                        <Trigger Property="Validation.HasError" Value="True">
                            <Setter Property="BorderBrush" Value="Red"/>
                            <Setter Property="ToolTip" 
          Value="{Binding RelativeSource={RelativeSource Self},
            Path=(Validation.Errors)[0].ErrorContent}"/>
                        </Trigger>
                    </Style.Triggers>
                </Style> 
            </DataGrid.Resources>
            
                <DataGrid.Columns>
                <DataGridTextColumn Header="Course Name"  Binding="{Binding Name, TargetNullValue=(enter a course name)}"/>
                    
                    
                <DataGridTextColumn Header="Course ID"  EditingElementStyle="{StaticResource errorStyle}"  Binding="{Binding Id, ValidatesOnExceptions=True}"/>
                    
                <DataGridTextColumn Header="Start Date" EditingElementStyle="{StaticResource errorStyle}"  Binding="{Binding StartDate, ValidatesOnExceptions=True}"/>
              
            </DataGrid.Columns>

        </DataGrid>
        <Button Content="Button" Height="23" HorizontalAlignment="Left" Margin="122,360,0,0" Name="button1" VerticalAlignment="Top" Width="75" Click="button1_Click" />
    </Grid>
</Window>

后台的逻辑代码的部分为:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Windows;
using System.Windows.Controls;
using System.Windows.Data;
using System.Windows.Documents;
using System.Windows.Input;
using System.Windows.Media;
using System.Windows.Media.Imaging;
using System.Windows.Navigation;
using System.Windows.Shapes;
using System.ComponentModel;
using System.Windows.Controls.Primitives;

namespace UserDemo3
{

    /// <summary>
    /// MainWindow.xaml 的交互逻辑
    /// </summary>
    public partial class MainWindow : Window
    {
        public MainWindow()
        {
            InitializeComponent();
            dGrid.InitializingNewItem += (sender, e) =>
            {
                //Course newCourse = e.NewItem as Course;
                //newCourse.StartDate = newCourse.EndDate = DateTime.Today;
            };

            #region ...
            List<Demo> listdemo = new List<Demo>();
            listdemo = new List<Demo>() { 
                new Demo(){ Id =1,Name=2,StartDate = 3 },
                   new Demo(){ Id =1,Name=2,StartDate = 3 },
                      new Demo(){ Id =1,Name=2,StartDate = 3}
            };
            dGrid.DataContext = listdemo;
            var obj = dGrid.CurrentCell;

            #endregion
        }

        private void dGrid_CellEditEnding(object sender, DataGridCellEditEndingEventArgs e)
        {
            #region ds

            DataGridRow dr = (DataGridRow)dGrid.ItemContainerGenerator.ContainerFromIndex(0); // 在这里进行列
            DataGridCellsPresenter presenter = GetVisualChild<DataGridCellsPresenter>(dr);
            DataGridCell cell = (DataGridCell)presenter.ItemContainerGenerator.ContainerFromIndex(2); //取第0列每行单元格
            cell.Focus();

            //System.Windows.Media.Brush

            #endregion
        }
        //点击事件
        private void button1_Click(object sender, RoutedEventArgs e)
        {

            #region ds
            int i = 0;
            if (i < dGrid.Items.Count)
            {
                DataGridRow dr = (DataGridRow)dGrid.ItemContainerGenerator.ContainerFromIndex(2);// 行
                DataGridCellsPresenter presenter = GetVisualChild<DataGridCellsPresenter>(dr);
                DataGridCell cell = (DataGridCell)presenter.ItemContainerGenerator.ContainerFromIndex(1); //列
                cell.Focus();

                //System.Windows.Media.Brush

            }
            #endregion
        }

        public static T GetVisualChild<T>(Visual parent) where T : Visual
        {
            T child = default(T);
            int numVisuals = VisualTreeHelper.GetChildrenCount(parent);
            for (int i = 0; i < numVisuals; i++)
            {
                Visual v = (Visual)VisualTreeHelper.GetChild(parent, i);
                child = v as T;
                if (child == null)
                {
                    child = GetVisualChild<T>(v);
                }
                if (child != null)
                {
                    break;
                }
            }
            return child;
        }
    }
    public class Demo
    {
        public int Id { get; set; }
        public int Name { get; set; }
        public int StartDate { get; set; }

    }



}

展示出来的效果为:

点击输入的时候如果不是数字的话,就会出现错误,点击按钮的时候会进行聚焦datagreade的当前的光标的位置

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
WPF,可以使用ValidationRule自定义验证规则并设置参数。首先,我们需要创建一个继承自ValidationRule的自定义验证规则类。在这个类,我们可以重写Validate方法来实现具体的验证逻辑。在方法的参数,我们可以通过传递参数来设置验证规则的值。比如,我们可以在类的构造函数传递一个参数,然后在Validate方法使用该参数进行验证。 例如,我们想要自定义一个验证规则,检查文本框的值是否为一个指定的长度。我们可以创建一个继承自ValidationRule的类,并添加一个长度参数: ``` public class LengthValidationRule : ValidationRule { public int Length { get; set; } public override ValidationResult Validate(object value, CultureInfo cultureInfo) { string input = value.ToString(); if (input.Length == Length) { // 验证通过 return ValidationResult.ValidResult; } else { // 验证失败,返回错误提示信息 return new ValidationResult(false, $"输入值长度应为{Length}位"); } } } ``` 然后,在XAML,我们可以将该验证规则应用于一个绑定的控件,同时设置规则的参数: ``` <TextBox> <TextBox.Text> <Binding Path="SomeProperty"> <Binding.ValidationRules> <local:LengthValidationRule Length="10" /> </Binding.ValidationRules> </Binding> </TextBox.Text> </TextBox> ``` 在上述代码,我们将该验证规则应用于绑定的TextBox控件,并设置Length属性为10,表示输入值需要为10位。当输入的值不满足验证规则时,会在TextBox周围显示验证错误的样式,并显示相应的错误提示信息。 总结来说,通过继承ValidationRule类并设置参数,我们可以在WPF自定义验证规则,并将其应用于需要验证的控件。这样可以轻松实现数据输入验证逻辑,并为用户提供相应的错误提示。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值