yycGIS

我们曾如此渴望命运的波澜,到最后才发现:人生最曼妙的风景,竟是内心的淡定与从容。 我们曾如此期盼外界的认可,到最后才知道:世界是自己的,与他人毫无关系。

Less is more, more is different!

导航

强大的DataGrid组件[1]

说明:DataGrid组件是Silverlight数据组件中最为常用并且是功能最为强大的数据组件。因此,对开发者而言,深入了解其特性是十分有必要的。本文先介绍该组件的基本特性,接着通过几个简单实例来说明该组件的基本数据操作过程。

 

组件所在命名空间:

System.Windows.Controls

 

组件常用方法:

BeginEdit:使DataGrid进入编辑状态。

CancelEdit:取消DataGrid的编辑状态。

CollapseRowGroup:闭合DataGrid的行分组。

CommitEdit:确认DataGrid的编辑完成。

ExpandRowGroup:展开DataGrid的行分组。

GetGroupFromItem:从具体Item中得到分组。

ScrollIntoView:滚动DataGrid视图。

 

组件常用属性:

AlternatingRowBackground:获取或设置一个笔刷用来描绘DataGrid奇数行的背景。

AreRowDetailsFrozen:获取或设置一个值用来判断是否冻结每行内容的详细信息。

AreRowGroupHeadersFrozen:获取或设置一个值用来判断是否冻结分组行的头部。

AutoGenerateColumns:获取或设置一个值用来判断是否允许自动生成表列。

CanUserReorderColumns:获取或设置一个值用来判断是否允许用户重新排列表列的位置。

CanUserSortColumns:获取或设置一个值用来判断是否允许用户按列对表中内容进行排序。

CellStyle:获取或设置单元格的样式。

ColumnHeaderHeight:获取或设置列头的高度。

ColumnHeaderStyle:获取或设置列头的样式。

Columns:获取组件中包含所有列的集合。

ColumnWidth:获取或设置列宽。

CurrentColumn:获取或设置包含当前单元格的列。

CurrentItem:获取包含当前单元格且与行绑定的数据项。

DragIndicatorStyle:获取或设置当拖曳列头时的样式。

DropLocationIndicatorStyle:获取或设置呈现列头时的样式。

FrozenColumnCount:获取或设置冻结列的个数。

GridLinesVisibility:获取或设置网格线的显示形式。

HeadersVisibility:获取或设置行头及列头的显示形式。

HorizontalGridLinesBrush:获取或设置水平网格线的笔刷。

HorizontalScrollBarVisibility:获取或设置水平滚动条的显示样式。

IsReadOnly:获取或设置DataGrid是否为只读。

MaxColumnWidth:获取或设置DataGrid的最大列宽。

MinColumnWidth:获取或设置DataGrid的最小列宽。

RowBackground:获取或设置用于填充行背景的笔刷。

RowDetailsTemplate:获取或设置被用于显示行详细部分的内容的模板。

RowDetailsVisibilityMode:获取或设置一个值用以判定行详细部分是否显示。

RowGroupHeaderStyles:获取呈现行分组头部的样式。

RowHeaderStyle:获取或设置呈现行头的样式。

RowHeaderWidth:获取或设置行头的宽度。

RowHeight:获取或设置每行的高度。

RowStyle:获取或设置呈现行时的样式。

SelectedIndex:获取或设置当前选中部分的索引值。

SelectedItem:获取或设置与当前被选中行绑定的数据项。

SelectedItems:获取与当前被选中的各行绑定的数据项们的列表(List)。

SelectionMode:获取或设置DataGrid的选取模式。

VerticalGridLinesBrush:获取或设置垂直网格线的笔刷。

VerticalScrollBarVisibility:获取或设置垂直滚动条的显示样式。

 

组件常用事件:

BeginningEdit:发生于一个单元格或行进入编辑模式之前。

CellEditEnded:发生于一个单元格编辑已被确认或取消。

CellEditEnding:发生于一个单元格正在结束编辑时。

CurrentCellChanged:发生于一个单元格成为当前单元格时。

PreparingCellForEdit:发生于在DataGridTemplateColumn下的单元格进入编辑模式时。

SelectionChanged:发生于当SelectedItemSelectedItems属性值改变时。

 

实例

DataGrid提供数据源的常用类型主要有两类:ListObservableCollection。前者一般用于普通数据绑定,而后者则常用于进行数据的双向绑定来保证数据的同步性。下面就分别给出这两种DataProvider的例子:

List

1)最简单的绑定

效果图:

MainPage.xaml文件代码

 1 <UserControl
 2     xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
 3     xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
 4     xmlns:d="http://schemas.microsoft.com/expression/blend/2008" xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
 5     mc:Ignorable="d" xmlns:data="clr-namespace:System.Windows.Controls;assembly=System.Windows.Controls.Data" x:Class="SilverlightClient.MainPage"
 6     Width="640" Height="480">
 7     <Grid x:Name="LayoutRoot" Background="White" Width="640" Height="480">
 8         <data:DataGrid x:Name="dgEmployee" Height="188" HorizontalAlignment="Left" Margin="18,19,0,0" VerticalAlignment="Top" Width="302"/>
 9     </Grid>
10 </UserControl>

MainPage.xaml.cs文件代码

 1 using System;
 2 using System.Collections.Generic;
 3 using System.Linq;
 4 using System.Net;
 5 using System.Windows;
 6 using System.Windows.Controls;
 7 using System.Windows.Documents;
 8 using System.Windows.Input;
 9 using System.Windows.Media;
10 using System.Windows.Media.Animation;
11 using System.Windows.Shapes;
12  
13 namespace SilverlightClient
14 {
15     public partial class MainPage : UserControl
16     {
17         public MainPage()
18         {
19             InitializeComponent();
20             this.Loaded += new RoutedEventHandler(MainPage_Loaded);
21         }
22  
23         void MainPage_Loaded(object sender, RoutedEventArgs e)
24         {
25             string dataSource = "H e l l o !";
26             string[] sp = { " " };
27             dgEmployee.ItemsSource = dataSource.Split(sp, StringSplitOptions.None).ToList();
28         }
29     }
30 }

2)使用业务对象

效果图:

MainPage.xaml文件代码

 1 <UserControl
 2     xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
 3     xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
 4     xmlns:d="http://schemas.microsoft.com/expression/blend/2008" xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
 5     mc:Ignorable="d" xmlns:data="clr-namespace:System.Windows.Controls;assembly=System.Windows.Controls.Data" x:Class="SilverlightClient.MainPage"
 6     Width="640" Height="480">
 7     <Grid x:Name="LayoutRoot" Background="White" Width="640" Height="480">
 8         <data:DataGrid x:Name="dgEmployee" Height="188" HorizontalAlignment="Left" Margin="18,19,0,0" VerticalAlignment="Top" Width="302"/>
 9     </Grid>
10 </UserControl>

MainPage.xaml.cs文件代码

 1 using System;
 2 using System.Collections.Generic;
 3 using System.Linq;
 4 using System.Net;
 5 using System.Windows;
 6 using System.Windows.Controls;
 7 using System.Windows.Documents;
 8 using System.Windows.Input;
 9 using System.Windows.Media;
10 using System.Windows.Media.Animation;
11 using System.Windows.Shapes;
12  
13 namespace SilverlightClient
14 {
15     //定义数据类
16     public class Employees
17     {
18         public int EmployeeID { get; set; }
19         public string EmployeeName { get; set; }
20         public int EmployeeAge { get; set; }
21  
22         public Employees()
23         { }
24  
25         public Employees(int employeeid, string employeename, int employeeage)
26         {
27             EmployeeID = employeeid;
28             EmployeeName = employeename;
29             EmployeeAge = employeeage;
30         }
31     }
32  
33     public partial class MainPage : UserControl
34     {
35         List<Employees> em = new List<Employees>();
36        
37         public MainPage()
38         {
39             InitializeComponent();
40             this.Loaded += new RoutedEventHandler(MainPage_Loaded);
41         }
42  
43         void MainPage_Loaded(object sender, RoutedEventArgs e)
44         {
45             em.Clear();
46             em.Add(new Employees(1, "张三", 23));
47             em.Add(new Employees(2, "李四", 24));
48             em.Add(new Employees(3, "王五", 25));
49  
50             dgEmployee.ItemsSource = em;
51         }
52     }
53 }

ObservableCollection

:要实现数据同步的双向绑定,则业务对象一定要实现INotifyPropertyChanged接口。

效果图

MainPage.xaml文件代码:

 1 <UserControl
 2     xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
 3     xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
 4     xmlns:d="http://schemas.microsoft.com/expression/blend/2008" xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
 5     mc:Ignorable="d" xmlns:data="clr-namespace:System.Windows.Controls;assembly=System.Windows.Controls.Data" x:Class="SilverlightClient.MainPage"
 6     Width="640" Height="480">
 7     <Grid x:Name="LayoutRoot" Background="White" Width="640" Height="480">
 8         <data:DataGrid x:Name="dgEmployee" Height="188" HorizontalAlignment="Left" Margin="18,19,0,0" VerticalAlignment="Top" Width="302"/>
 9          <ListBox x:Name="lbSynchronization" HorizontalAlignment="Left" Margin="18,231,0,71" Width="302"/>
10     </Grid>
11 </UserControl>

MainPage.xaml.cs文件代码

 1 using System;
 2 using System.Collections.Generic;
 3 using System.Collections.ObjectModel;
 4 using System.Linq;
 5 using System.Net;
 6 using System.Windows;
 7 using System.Windows.Controls;
 8 using System.Windows.Documents;
 9 using System.Windows.Input;
10 using System.Windows.Media;
11 using System.Windows.Media.Animation;
12 using System.Windows.Shapes;
13 using System.ComponentModel;
14  
15 namespace SilverlightClient
16 {
17     public class Employees : INotifyPropertyChanged
18     {
19         private string name;
20         public string  EmployeeName
21         {
22           get  { return name; }
23           set 
24           {
25             if( value != name)
26             {
27               name  = value;
28               onPropertyChanged(this, "EmployeeName");
29             }
30           }
31         }
32         public event PropertyChangedEventHandler PropertyChanged;
33  
34         private void onPropertyChanged(object sender, string propertyName){
35  
36         if(this.PropertyChanged != null)
37         {
38            PropertyChanged(sender,new PropertyChangedEventArgs(propertyName)) ;
39         }
40     }
41  
42         public Employees()
43         { }
44  
45         public Employees(string employeename)
46         {
47             EmployeeName = employeename;
48         }
49     }
50  
51     public partial class MainPage : UserControl
52     {
53         ObservableCollection<Employees> getEmployeesCollection()
54         {
55             ObservableCollection<Employees> rVal = new ObservableCollection<Employees>();
56  
57             rVal.Add(new Employees { EmployeeName = "Tim" });
58             rVal.Add(new Employees { EmployeeName = "Mary" });
59             rVal.Add(new Employees { EmployeeName = "John" });
60            
61             return rVal;
62         }
63  
64         public ObservableCollection<Employees> em;
65  
66         public MainPage()
67         {
68             InitializeComponent();
69             this.Loaded += new RoutedEventHandler(MainPage_Loaded);
70         }
71  
72         void MainPage_Loaded(object sender, RoutedEventArgs e)
73         {
74             em = getEmployeesCollection();
75             dgEmployee.ItemsSource = em;
76             lbSynchronization.ItemsSource = em;
77             lbSynchronization.DisplayMemberPath = "EmployeeName";
78         }
79     }
80 }

 

文章来源:http://www.cnblogs.com/Kinglee/archive/2009/08/14/1546507.html

 

 

posted on 2014-05-19 11:06  yycGIS  阅读(432)  评论(0编辑  收藏  举报