c#-DataGridView控件实现分页

有时候我们需要进行分页显示,第一方面是在大数据量下可以降低卡顿,另一方面也是方便查找。

首先划重点,如果卡顿,不要用单元格填充的方式去刷新,用绑定数据源的方式比较高效!

下面重点讲如何使用数据源绑定数据的方式,对数据进行分页展示。

本文中配合使用了BindingNavigator控件,该控件有很多功能,因为开发时间比较紧急,下文中仅使用该控件进行按钮的替代。

效果如下:

目录

1.设置

按钮及对应名称如下:

ps:这个控件和工具栏很像,后续有时间我们再谈。

其他全局参数

csharp 复制代码
DataTable dt_DevState = new DataTable("state");//源数据,大家自行获取(未分页前的所有数据)
public int pageSize = 5;//一页显示多少行
int pageCount = 0;
/// <summary>
/// 总页数
/// </summary>
public int PageCount
{
    get
    {
        if (dt_DevState != null)
        {
            pageCount = (int)Math.Ceiling(dt_DevState.Rows.Count * 1.0 / pageSize);
        }
        return pageCount;
    }
}
int currentPage = 1;
/// <summary>
/// 当前页
/// </summary>
public int CurrentPage
{
    get { return currentPage; }
    set
    {
        if (value <= 1)
        {
            value = 1;
            this.bdFirstItem.Enabled = false;
            this.bdPreviousItem.Enabled = false;
            this.bdNextItem.Enabled = true;
            this.bdLastItem.Enabled = true;
        }
        else if (value >= PageCount)
        {
            value = pageCount;
            this.bdFirstItem.Enabled = true;
            this.bdPreviousItem.Enabled = true;
            this.bdNextItem.Enabled = false;
            this.bdLastItem.Enabled = false;
        }
        else
        {
            this.bdFirstItem.Enabled = true;
            this.bdPreviousItem.Enabled = true;
            this.bdNextItem.Enabled = true;
            this.bdLastItem.Enabled = true;

        }
        currentPage = value;
    }
}
int currentRow;
/// <summary>
/// 每页首行索引
/// </summary>
public int CurrentRow
{
    get
    {
        if (CurrentPage == 1)
        {
            currentRow = 0;
        }
        else
        {
            currentRow = (CurrentPage - 1) * pageSize;
        }
        return currentRow;
    }
}
int max = 0;
/// <summary>
/// 每页行数最大值索引
/// </summary>
public int Max
{
    get
    {
        if (CurrentPage == pageCount)
        {
            max = dt_DevState.Rows.Count;
        }
        else
        {
            max = pageSize * CurrentPage;
        }
        return max;
    }
}

2.初始化

根据DataGridView控件大小,获取DataGridView每页显示的行数:

csharp 复制代码
private void dataGridView1_SizeChanged(object sender, EventArgs e)
{

   pageSize = (dataGridView1.Height-dataGridView1.ColumnHeadersHeight)/ dataGridView1.RowTemplate.Height;
   BindPage();
}

绑定下拉框中的页码:

csharp 复制代码
private void BindPage()
{
    bindingNavigator1.Enabled = true;
    this.bdCountItem.Text = PageCount.ToString();
    this.tspcbo.Items.Clear();
    for (int i = 1; i <= pageCount; i++)
    {
        this.tspcbo.Items.Add("第" + i + "页");
    }
    if(tspcbo.Items.Count>0)
         this.tspcbo.SelectedIndex = 0;

}

3.按钮绑定事件

按钮按下后更新下拉列表控件的显示内容,实现分页显示。

csharp 复制代码
private void tspcbo_SelectedIndexChanged(object sender, EventArgs e)
{
	//下拉框选择不同页码更新表显示
     CurrentPage = this.tspcbo.SelectedIndex + 1;
     this.bdPositionItem.Text = CurrentPage.ToString();
     if (!this.IsHandleCreated) return;
     this.BeginInvoke(new EventHandler(delegate
     {
         UpdateTable();//更新数据,在步骤4中有代码
     }));
     
 }
 private void bdFirstItem_Click(object sender, EventArgs e)
 {
     this.tspcbo.SelectedIndex = 0;
 }

 private void bdPreviousItem_Click(object sender, EventArgs e)
 {
     this.tspcbo.SelectedIndex = CurrentPage - 2;
 }

 private void bdNextItem_Click(object sender, EventArgs e)
 {
     this.tspcbo.SelectedIndex = CurrentPage;
 }

 private void bdLastItem_Click(object sender, EventArgs e)
 {
     this.tspcbo.SelectedIndex = PageCount - 1;
 }

4.更新数据

csharp 复制代码
public void UpdateTable()
{
    if (!dataGridView1.Visible) return;
    dataGridView1.SuspendLayout();
    var dt_Page = BindSourceFY();
    dataGridView1.DataSource = dt_Page.Copy();
    dataGridView1.ResumeLayout();
}


/// <summary>
/// 分页绑定数据
/// </summary>
private DataTable BindSourceFY()
{
    if (dt_DevState == null|| dt_DevState.Rows.Count==0) return dt_DevState;
    DataTable dt_Page = dt_DevState.Clone();
    for (int i = CurrentRow; i < Max; i++)
    {
        dt_Page.ImportRow(dt_DevState.Rows[i]);
    }
    return dt_Page;
}
相关推荐
Aimeast5 小时前
关于选择最佳.NET Core SSH服务器库的全面分析
c#·ssh
蒋劲豪6 小时前
WPF项目暴露WebApi接口;WinForm项目暴露WebApi接口;C#项目暴露WebApi接口;
开发语言·c#·wpf
code bean7 小时前
【C# 数据结构】队列 FIFO
开发语言·数据结构·c#
时光追逐者9 小时前
推荐几款开源免费的 .NET MAUI 组件库
microsoft·开源·c#·.net·.net core·maui
软件黑马王子11 小时前
C#初级教程(1)——C# 与.NET 框架:探索微软平台编程的强大组合
开发语言·c#
shepherd枸杞泡茶11 小时前
第3章 3.2 配置系统 .NET Core配置系统
后端·c#·asp.net·.net
编程乐趣12 小时前
一文掌握DeepSeek本地部署+Page Assist浏览器插件+C#接口调用+局域网访问!全攻略来了!
开发语言·c#
我是苏苏13 小时前
C#基础:使用Linq进行简单去重处理(DinstinctBy/反射)
开发语言·c#·linq
小小码农(找工作版)13 小时前
C#前端开发面试题
开发语言·c#
局外人_Jia15 小时前
C# 十六进制字符串转换为十进制
服务器·开发语言·c#