C# Winform Datagridview控件使用和详解

        DataGridView 是一种以表格形式显示数据的控件,由Rows(行),Columns(列),Cells(单元格)构成。本实例将综合利用DataGridView的属性和事件,展示不同的表格风格数据和操作。包含:

  • 添加Datagridview行,列数据
  • 设置列单元格不同的控件形式(TextBox,Button,ComboBox,CheckBox,Image,Link)
  • 单元格显示多个控件,及控件绑定行,列信息
  • 编辑,删除行数据
  • 复制表格和单元格数据
  • 查询,定位表格数据
  • Datagridview行间隔颜色
  • 单元格有效值判断
  • 自定义Datagridview扩展控件
  • 合并单元格

Datagridview基本属性:

  • DataSource 设置DataGridView 控件的数据源,常用的数据源类型有:DataTable,List集合。
  • Rows: 通过此属性可以访问或操作行集合中的行。
  • Columns: 通过此属性可以访问或操作列集合中的列。
  • Cell: 表示 DataGridView 控件中的一个单元格。
  • Value: 单元格存储的实际数据。
  • Selected: 表示单元格是否被选中。
  • RowIndex: 单元格所在的行索引。
  • ColumnIndex: 单元格所在的列索引。

Datagridview常用属性:

  • AllowUserToAddRows:控制是否显示用于添加新行的空白行。
  • AllowUserToDeleteRows:控制用户是否可以从 DataGridView 中删除行,默认值为 true。用户可以通过选中行并按 Delete 键来删除行。
  • AllowUserToOrderColumns:控制是否允许用户手动调整列的位置。True: 允许用户通过拖动来重新放置列。False: 不允许用户手动调整列的位置。
  • AllowUserToResizeColumns: 是否允许用户调整列宽。
  • AllowUserToResizeRows: 是否允许用户调整行高。
  • AutoSizeColumnsMode: 确定列的自动大小调整模式。
  • AutoSizeRowsMode: 确定行的自动大小调整模式。
  • EditMode: 定义何时可以编辑单元格的内容。
  • GridColor: 网格线的颜色。
  • MultiSelect: 是否允许用户同时选择多个单元格、行或列。
  • SelectionMode: 设置单元格选择模式。
  • ColumnType: 列的类型,例如 DataGridViewTextBoxColumn, DataGridViewCheckBoxColumn 等。
  • DataPropertyName: 绑定到数据源的属性名。
  • HeaderText: 列标题显示的文本。
  • Selected: 行是否被选中。
  • State: 行的状态。
  • OwningColumn: 所属的列。
  • ColumnIndex: 所在列的索引。
  • FormattedValue: 显示格式化后的值。
  • FormattedValueType: 格式化值的类型。
  • ValueType: 单元格值的数据类型。

Datagridview常用事件:

  • CellClick:单元格单击事件,点击单元格触发。
  • CellContentClick:单元格内容单击事件,必须点击到表格内的内容时才能触发事件。
  • CellChanged事件:点击表格内任意部分即可触发事件。
  • CellValueChanged:初始化和内容提交后(失去焦点后)触发事件
  • CurrentCellDirtyStateChanged:内容被修改后,触发事件(立即)
  • CellBeginEdit:单元格编辑前的值
  • CellEndEdit:单元格编辑后的值

参考:

【WinForm详细教程七】WinForm中的DataGridView控件_winform datagridview-CSDN博客

工程代码实例:

https://download.csdn.net/download/lvxingzhe3/89432596

  • 6
    点赞
  • 15
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
C# 可视化 WinForm 中,可以使用 DataGridView 控件来显示数据,并且可以实现分页功能。下面是一个简单的实现分页功能的示例代码: 首先,在窗体中添加一个 DataGridView 控件和两个 Button 控件,一个用于上一页,一个用于下一页。然后在窗体的 Load 事件中,初始化 DataGridView 控件并设置数据源: ``` private void Form1_Load(object sender, EventArgs e) { // 初始化 DataGridView 控件 dataGridView1.AutoGenerateColumns = true; dataGridView1.SelectionMode = DataGridViewSelectionMode.FullRowSelect; dataGridView1.MultiSelect = false; dataGridView1.ReadOnly = true; // 设置数据源 dataGridView1.DataSource = GetData(1, pageSize); } ``` 其中,GetData() 方法用于获取数据源,第一个参数表示当前页码,第二个参数表示每页显示的数据条数。这个方法需要根据具体的业务逻辑来实现。 接下来,实现上一页和下一页的按钮点击事件: ``` private void btnPrev_Click(object sender, EventArgs e) { if (currentPage > 1) { currentPage--; dataGridView1.DataSource = GetData(currentPage, pageSize); } } private void btnNext_Click(object sender, EventArgs e) { if (currentPage < totalPages) { currentPage++; dataGridView1.DataSource = GetData(currentPage, pageSize); } } ``` 其中,currentPage 表示当前页码,totalPages 表示总页数。在点击上一页和下一页按钮时,需要判断当前是否到达了第一页或最后一页,如果没有,则更新当前页码并重新设置数据源。 最后,需要根据总数据条数和每页显示的数据条数计算总页数,并在窗体中显示出来: ``` private void DisplayPageInfo() { // 计算总页数 int totalCount = GetTotalCount(); totalPages = (int)Math.Ceiling((double)totalCount / pageSize); // 显示当前页码和总页数 lblPageInfo.Text = string.Format("第 {0} 页,共 {1} 页", currentPage, totalPages); } ``` 其中,GetTotalCount() 方法用于获取总数据条数,需要根据具体的业务逻辑来实现。 完整的代码示例: ``` public partial class Form1 : Form { private int pageSize = 10; // 每页显示的数据条数 private int currentPage = 1; // 当前页码 private int totalPages = 0; // 总页数 public Form1() { InitializeComponent(); } private void Form1_Load(object sender, EventArgs e) { // 初始化 DataGridView 控件 dataGridView1.AutoGenerateColumns = true; dataGridView1.SelectionMode = DataGridViewSelectionMode.FullRowSelect; dataGridView1.MultiSelect = false; dataGridView1.ReadOnly = true; // 设置数据源 dataGridView1.DataSource = GetData(1, pageSize); // 显示当前页码和总页数 DisplayPageInfo(); } private void btnPrev_Click(object sender, EventArgs e) { if (currentPage > 1) { currentPage--; dataGridView1.DataSource = GetData(currentPage, pageSize); DisplayPageInfo(); } } private void btnNext_Click(object sender, EventArgs e) { if (currentPage < totalPages) { currentPage++; dataGridView1.DataSource = GetData(currentPage, pageSize); DisplayPageInfo(); } } private void DisplayPageInfo() { // 计算总页数 int totalCount = GetTotalCount(); totalPages = (int)Math.Ceiling((double)totalCount / pageSize); // 显示当前页码和总页数 lblPageInfo.Text = string.Format("第 {0} 页,共 {1} 页", currentPage, totalPages); } private DataTable GetData(int pageNum, int pageSize) { // 根据当前页码和每页显示的数据条数获取数据源 // 这里只是一个示例,需要根据具体的业务逻辑来实现 DataTable dt = new DataTable(); dt.Columns.Add("ID", typeof(int)); dt.Columns.Add("Name", typeof(string)); dt.Columns.Add("Age", typeof(int)); for (int i = 1; i <= pageSize; i++) { int id = (pageNum - 1) * pageSize + i; dt.Rows.Add(id, "Name" + id, 20 + i); } return dt; } private int GetTotalCount() { // 获取总数据条数 // 这里只是一个示例,需要根据具体的业务逻辑来实现 return 100; } } ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

无熵~

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值