美文网首页
WPF之DataGrid

WPF之DataGrid

作者: 小羊爱学习 | 来源:发表于2024-08-21 16:19 被阅读0次

常用属性

属性名 含义
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

  1. DataTable
    定义:DataTable表示内存中数据的一个表,它是完全在内存中的一个独立存在,包含了这张表的全部信息。DataTable可以是从数据库中读取数据后形成的表,也可以是由程序通过代码创建的表。
    功能:DataTable用于存储和操作结构化数据,它由行(DataRow)和列(DataColumn)组成,类似于数据库中的表。DataTable支持添加、删除、修改行和列,以及对数据进行排序和筛选等操作。
    用途:DataTable常用于在内存中缓存数据,以便进行离线操作或在没有数据库连接的情况下处理数据。
  2. DataView
    定义:DataView表示用于排序、筛选、搜索、编辑和导航的DataTable的可绑定数据的自定义视图。
    功能:DataView允许用户对DataTable中的数据进行排序、筛选和查看不同版本的数据(如原始版本和当前版本)。它提供了RowFilter、Sort和RowStateFilter等属性,用于控制视图中显示的数据。
    用途:DataView常用于在用户界面(如Windows窗体或Web窗体)中显示DataTable中的数据,同时允许用户根据需要对数据进行排序和筛选。
  3. DataRow
    定义:DataRow是DataTable中的一行数据。
    功能:DataRow表示DataTable中的一行,它包含了该行的所有列值。DataRow支持访问和修改列值,以及检查行的状态(如是否已修改、是否已删除等)。
    用途:DataRow用于在DataTable中操作具体的数据行,如读取数据、修改数据或删除数据。
  4. 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();  
}

相关文章

网友评论

      本文标题:WPF之DataGrid

      本文链接:https://www.haomeiwen.com/subject/cdkekjtx.html