常用属性
属性名 |
含义 |
RowHeaderTemplate |
行标题模板 |
RowHeaderStyle |
行标题样式 |
ColumnHeaderStyle |
列标题样式 |
CanUserAddRows |
是否添加新行 |
IsReadOnly |
是否可以编辑其中的值 |
VerticalScrollBarVisibility/HorizontalScrollBarVisibility |
垂直/水平滚动条的显示 |
CurrentItem |
当前单元格的行绑定的数据项 |
CanUserDeleteRows |
是否可以删除行 |
RowStyle/CellStyle |
行/单元格 样式 |
HeadersVisibility |
行和列头的可见性 |
AlternatingRowBackground |
交替行上使用的背景画笔 |
GridLinesVisibility |
显示哪些网格线 |
VerticalGridLinesBrush/HorizontalGridLinesBrush |
垂直/水平网格线画笔 |
RowHeaderWidth/ColumnHeaderHeight |
行/列标题宽度 |
RowHeight |
行高 |
AutoGenerateColumns |
是否自动创建列 |
SelectionUnit/SelectionMode |
选择单元(单元格、行或两者)/单选或多选 |
ItemsSource |
设置数据源 |
DataGridColumn列样式
样式名 |
含义 |
DataGridTextColumn |
文本显示,类型string |
DataGridCheckBoxColumn |
复选框,类型Boolean |
DataGridComboBoxColumn |
下拉列表,类型Enum |
DataGridHyperlinkColumn |
超链接,类型Uri |
DataGridTemplateColumn |
自定义模板列 |
数据绑定
1.在WPF中,DataGrid 的 ItemsSource 属性可以设置的对象类型非常灵活,它可以是任何实现了 IEnumerable 接口的集合,包括 List<T> 和 DataView。
- 当 ItemsSource 设置为 List<T> 时,DataGrid 会直接显示列表中的元素,每个元素对应一行。
// 检查是否有选中项
if (clientDataGrid.SelectedItem != null)
{
ClientInfo info = (ClientInfo)clientDataGrid.SelectedItem;
}
- 当 ItemsSource 设置为 DataView 时,DataGrid 会显示 DataView 中的数据,这些数据来自于与之关联的 DataTable。DataView 提供了对数据进行排序、筛选和搜索等功能,而这些更改都会实时反映在 DataGrid 上。
this.clientDataGrid.ItemsSource = dataTable.DefaultView;
DataRowView mySelected = (DataRowView)this.clientDataGrid.SelectedItem;
当DataGrid.ItemsSource设置为DataTable时:DataGrid.SelectedItem的类型将是DataRowView。这是因为DataTable的默认视图(当你没有显式指定DataView时)实际上是一个DataRowView的集合,每个DataRowView包装了一个DataRow并提供了对其数据的访问。当你选择DataGrid中的一行时,你实际上是在选择一个DataRowView对象。
当DataGrid.ItemsSource设置为DataView时:DataGrid.SelectedItem的类型仍然是DataRowView。这是因为DataView本身就是DataRowView的集合。当你选择DataGrid中的一行时,你同样是在选择一个DataRowView对象,这个对象代表了DataView中当前被选中的行。
DataTable dataTable = new DataTable();
// 假设dataTable已经被填充了数据
dataGrid.ItemsSource = dataTable.DefaultView; // 或者直接使用dataTable,但使用DataView提供了更多灵活性
dataGrid.AutoGenerateColumns = true; // 确保列是自动生成的
事件
事件名 |
含义 |
AutoGeneratingColumn |
在自动生成列时发生。可以使用此事件修改生成的列 |
.BeginningEdit 和 CellEditEnding |
分别表示开始编辑单元格和结束编辑单元格。可以使用这些事件对编辑进行验证或其他处理。 |
Sorting |
在排序前发生。可以使用此事件取消排序,或根据需要修改排序方式。 |
SelectionChanged |
在选择内容更改时发生。可以使用此事件对选定的行或单元格进行操作。 |
PreviewKeyDown 和 KeyDown |
分别表示键被按下之前和之后。可以使用这些事件捕获特定键的按下事件,并执行相应的操作。 |
MouseDoubleClick 和 PreviewMouseDoubleClick |
分别表示鼠标双击之前和之后。可以使用这些事件捕获鼠标双击事件,并执行相应的操作。 |
|
CurrentCellChanged |
在当前单元格更改时发生。可以使用此事件对当前单元格进行操作。 |
LoadingRow |
在每一行加载时发生。可以使用此事件对行进行初始化或其他处理。 |
UnloadingRow |
在每一行卸载时发生。可以使用此事件对行进行资源释放或其他处理。 |
RowEditEnding |
当行编辑完成并退出编辑模式时发生。可以使用此事件对行数据进行验证或其他处理。 |
DataTable、DataView、DataRow和DataRowView
- DataTable
定义:DataTable表示内存中数据的一个表,它是完全在内存中的一个独立存在,包含了这张表的全部信息。DataTable可以是从数据库中读取数据后形成的表,也可以是由程序通过代码创建的表。
功能:DataTable用于存储和操作结构化数据,它由行(DataRow)和列(DataColumn)组成,类似于数据库中的表。DataTable支持添加、删除、修改行和列,以及对数据进行排序和筛选等操作。
用途:DataTable常用于在内存中缓存数据,以便进行离线操作或在没有数据库连接的情况下处理数据。
- DataView
定义:DataView表示用于排序、筛选、搜索、编辑和导航的DataTable的可绑定数据的自定义视图。
功能:DataView允许用户对DataTable中的数据进行排序、筛选和查看不同版本的数据(如原始版本和当前版本)。它提供了RowFilter、Sort和RowStateFilter等属性,用于控制视图中显示的数据。
用途:DataView常用于在用户界面(如Windows窗体或Web窗体)中显示DataTable中的数据,同时允许用户根据需要对数据进行排序和筛选。
- DataRow
定义:DataRow是DataTable中的一行数据。
功能:DataRow表示DataTable中的一行,它包含了该行的所有列值。DataRow支持访问和修改列值,以及检查行的状态(如是否已修改、是否已删除等)。
用途:DataRow用于在DataTable中操作具体的数据行,如读取数据、修改数据或删除数据。
- DataRowView
定义:DataRowView是DataView中的一行数据的视图。
功能:DataRowView提供了对DataView中当前行的访问,它允许用户获取和设置当前行的列值,以及检查行的状态。DataRowView还提供了对原始版本和当前版本数据的访问。
用途:DataRowView常用于在数据绑定场景中,如将数据绑定到Windows窗体或Web窗体中的控件时,使用DataRowView可以方便地访问和操作当前行的数据。
// 假设dataGrid是你的DataGrid控件的实例
//这段代码适用于DataGrid.ItemsSource被设置为DataTable或DataView的情况。
if (dataGrid.SelectedItem != null)
{
DataRowView selectedRowView = (DataRowView)dataGrid.SelectedItem;
DataRow selectedRow = selectedRowView.Row;
// 现在你可以通过selectedRow来访问选中行的数据了
// 例如,如果DataTable中有一个名为"Name"的列
string name = selectedRow["Name"].ToString();
}