Silverlight之我见——DataGrid数据验证

用DataGrid进行数据验证,一句话:太简单了,为什么?因为它自身已经具备了很完善的数据验证功能。
好,说多无益,最好的办法,来,写个例子试试。
老规矩,先准备点数据来测试,既然要数据验证,就不能全弄字符串的,弄点整型的,日期型的,这样就有利于演示。
public class Employee { public string Name { get; set; } public int Age { get; set; } public DateTime Birthday { get; set; } }
该类声明三个属性,分别是字符串,整型,日期型。
好,我们来看看DataGrid默认的验证功能。
要进行验证只需做好以下工作:
把Binding的ValidatesOnExceptions设为True,NotifyOnValidationError设为true,UpdateSourceTrigger设置为Explicit。
好,看XAML:
<UserControl x:Class="DataValidationSample.MainPage" xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation" xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml" xmlns:d="http://schemas.microsoft.com/expression/blend/2008" xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006" mc:Ignorable="d" d:DesignWidth="640" d:DesignHeight="480" xmlns:sdk="clr-namespace:System.Windows.Controls;assembly=System.Windows.Controls.Data"> <Grid x:Name="LayoutRoot"> <sdk:DataGrid x:Name="Grid" CanUserReorderColumns="True" CanUserSortColumns="True" AutoGenerateColumns="False"> <sdk:DataGrid.Columns> <!--声明列,并进行绑定--> <sdk:DataGridTextColumn Header="姓名" Width="auto"> <sdk:DataGridTextColumn.Binding> <Binding Path="Name" Mode="TwoWay" UpdateSourceTrigger="Explicit" ValidatesOnExceptions="True" NotifyOnValidationError="True"/> </sdk:DataGridTextColumn.Binding> </sdk:DataGridTextColumn> <sdk:DataGridTextColumn Header="年龄" Width="auto"> <sdk:DataGridTextColumn.Binding> <Binding Path="Age" Mode="TwoWay" ValidatesOnExceptions="True" NotifyOnValidationError="True" UpdateSourceTrigger="Explicit"/> </sdk:DataGridTextColumn.Binding> </sdk:DataGridTextColumn> <sdk:DataGridTextColumn Header="生日" Width="auto"> <sdk:DataGridTextColumn.Binding> <Binding Path="Birthday" Mode="TwoWay" ValidatesOnExceptions="True" NotifyOnValidationError="True" UpdateSourceTrigger="Explicit"/> </sdk:DataGridTextColumn.Binding> </sdk:DataGridTextColumn> </sdk:DataGrid.Columns> </sdk:DataGrid> </Grid> </UserControl>
最后,在类用户控制的构造函数中设置数据源。
public partial class MainPage : UserControl { ObservableCollection<Employee> Employs = null; public MainPage() { InitializeComponent(); this.Employs = new ObservableCollection<Employee>(); Employs.Add(new Employee { Name = "李小同", Age = 27, Birthday = new DateTime(1988, 12, 10) }); Employs.Add(new Employee { Name = "南郭先生", Age = 43, Birthday = new DateTime(1976, 3, 12) }); Employs.Add(new Employee { Name = "汤老头", Age = 36, Birthday = new DateTime(1978, 5, 1) }); Employs.Add(new Employee { Name = "林大吉", Age = 28, Birthday = new DateTime(1987, 6, 21) }); //绑定 this.Grid.ItemsSource = Employs; } }
好了,请申出你的手指头,轻轻地按一下F5,把程序Run起来。
我们在年龄上选一条记录,进入编辑状态后,输入字母(应为整数),然后试着确认,看看发生了什么事?

在日期处也试试。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值