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;
}
相关推荐
百锦再31 分钟前
.NET 的 WebApi 项目必要可配置项都有哪些?
java·开发语言·c#·.net·core·net
WYH28711 小时前
C#控制台输入(Read()、ReadKey()和ReadLine())
开发语言·c#
hqwest12 小时前
C#WPF实战出真汁06--【系统设置】--餐桌类型设置
c#·.net·wpf·布局·分页·命令·viewmodel
做一位快乐的码农15 小时前
基于.net、C#、asp.net、vs的保护大自然网站的设计与实现
c#·asp.net·.net
DavieLau15 小时前
C#项目WCF接口暴露调用及SOAP接口请求测试(Python版)
xml·服务器·开发语言·python·c#
张人玉15 小时前
C#Encoding
开发语言·c#
hqwest18 小时前
C#WPF实战出真汁05--左侧导航
开发语言·c#·wpf·主界面·窗体设计·视图viewmodel
小码编匠20 小时前
C# Bitmap 类在工控实时图像处理中的高效应用与避坑
后端·c#·.net
Kyln.Wu1 天前
【python实用小脚本-187】Python一键批量改PDF文字:拖进来秒出新文件——再也不用Acrobat来回导
python·pdf·c#
hqwest1 天前
C#WPF实战出真汁01--项目介绍
开发语言·c#·wpf