C# 实现 DataGridView 分页与全选功能
需积分: 9 26 浏览量
更新于2024-09-13
收藏 102KB DOC 举报
"这篇文章主要介绍了如何在C#中使用DataGridView控件实现分页和全选功能,通过结合BindingNavigator和BindingSource控件来达到目的。"
在C#开发Windows Forms应用时,`DataGridView`控件通常用于显示大量数据。为了提高用户体验并优化性能,我们可能需要实现分页功能,使得用户能逐页浏览数据,而不是一次性加载所有记录。此外,全选功能也是常见需求,允许用户一次性选择所有行。本文将介绍如何在C#中实现这两个功能。
首先,我们需要引入以下关键控件:
1. `DataGridView` - 用于显示数据的表格控件。
2. `BindingNavigator` - 提供导航按钮,如“上一页”、“下一页”,以及显示当前页和总页数。
3. `BindingSource` - 作为数据源和`DataGridView`之间的中介,帮助管理数据的分页。
以下是实现步骤:
1. 初始化变量:
定义几个私有变量,如`pageSize`表示每页显示的行数,`nMax`表示总记录数,`pageCount`表示总页数,`pageCurrent`表示当前页号,`nCurrent`表示当前记录行。同时,创建一个`DataSet`对象`ds`和一个`DataTable`对象`dtInfo`来存储数据。
2. 构造函数:
在`Form1`的构造函数中,初始化控件,如果需要自定义列,例如添加一个复选框列,可以在这里进行设置。但若不需手动添加,这部分代码可以注释掉。
3. 加载事件:
在`Form1_Load`事件处理程序中,建立与数据库的连接,执行SQL查询获取数据,并将数据填充到`DataSet`的`DataTable`中。然后调用`InitDataSet`方法初始化分页参数,并设置`DataGridView`的数据源为`dtInfo`。
4. InitDataSet方法:
在这个方法中,设定每页显示的行数(例如5行),计算总记录数`nMax`(即`dtInfo.Rows.Count`),进而计算总页数`pageCount`(`nMax/pageSize`,向下取整)。同时,初始时,当前页号`pageCurrent`设为1,当前记录行`nCurrent`设为0。
5. BindingNavigator的事件处理:
需要处理`BindingNavigator`的`BindingNavigatorMoveFirst`、`BindingNavigatorMovePrevious`、`BindingNavigatorMoveNext`和`BindingNavigatorMoveLast`事件,以更新当前页号和记录行,同时刷新`DataGridView`显示的内容。
6. 全选/取消全选功能:
可以添加两个按钮或使用快捷键实现全选和取消全选。在事件处理程序中,使用`DataGridView`的`SelectAll`方法选择所有行,或者清空`SelectedRows`集合取消选择。
示例代码可能如下:
```csharp
private void bindingNavigatorMoveFirst_Click(object sender, EventArgs e)
{
pageCurrent = 1;
nCurrent = 0;
RefreshDataGridView();
}
private void bindingNavigatorMovePrevious_Click(object sender, EventArgs e)
{
if (pageCurrent > 1)
{
pageCurrent--;
nCurrent -= pageSize;
}
RefreshDataGridView();
}
private void bindingNavigatorMoveNext_Click(object sender, EventArgs e)
{
if (pageCurrent < pageCount)
{
pageCurrent++;
nCurrent += pageSize;
}
RefreshDataGridView();
}
private void bindingNavigatorMoveLast_Click(object sender, EventArgs e)
{
pageCurrent = pageCount;
nCurrent = (pageCount - 1) * pageSize;
RefreshDataGridView();
}
private void RefreshDataGridView()
{
int startIndex = (pageCurrent - 1) * pageSize;
dataGridView1.CurrentCell = null;
dataGridView1.DataSource = dtInfo.DefaultView.ToTable(true, null, null, startIndex, pageSize);
}
private void btnselectAll_Click(object sender, EventArgs e)
{
dataGridView1.SelectAll();
}
private void btnCancelSelect_Click(object sender, EventArgs e)
{
dataGridView1.ClearSelection();
}
```
通过以上步骤,我们可以实现`DataGridView`的分页和全选功能。记得在实际项目中根据具体需求进行调整和优化,确保用户体验和代码的可维护性。
2020-10-15 上传
2018-11-26 上传
2022-04-07 上传
2011-01-14 上传
2022-09-20 上传
2011-05-19 上传
2012-05-02 上传
2007-10-14 上传
fly_wei66
- 粉丝: 0
- 资源: 1
最新资源
- MATLAB新功能:Multi-frame ViewRGB制作彩色图阴影
- XKCD Substitutions 3-crx插件:创新的网页文字替换工具
- Python实现8位等离子效果开源项目plasma.py解读
- 维护商店移动应用:基于PhoneGap的移动API应用
- Laravel-Admin的Redis Manager扩展使用教程
- Jekyll代理主题使用指南及文件结构解析
- cPanel中PHP多版本插件的安装与配置指南
- 深入探讨React和Typescript在Alias kopio游戏中的应用
- node.js OSC服务器实现:Gibber消息转换技术解析
- 体验最新升级版的mdbootstrap pro 6.1.0组件库
- 超市盘点过机系统实现与delphi应用
- Boogle: 探索 Python 编程的 Boggle 仿制品
- C++实现的Physics2D简易2D物理模拟
- 傅里叶级数在分数阶微分积分计算中的应用与实现
- Windows Phone与PhoneGap应用隔离存储文件访问方法
- iso8601-interval-recurrence:掌握ISO8601日期范围与重复间隔检查