如何把DGV分页写成方法。

我自己之前边学边搞了个DGV的分页。但是目前写在窗体里面的。由于很多页面都需要写分页,想把这个弄成可以调用的方法。本人自学的,知识不系统,望各位指教,希望能够直观一点,谢谢!
代码如下:

 public partial class GW_Form : Form
    {
        public int pageSize = 30; //每页记录数
        public int recordCount = 0;  //总记录数
        public int pageCount = 0; //总页数 
        public int currentPage = 0; //当前页
        DataTable dt=null;
        GWBLL gWBLL=new GWBLL(); //查询全部数据方法
        private void PageSorter()
        {
            uiDataGridView1.AllowUserToAddRows = false;
            uiDataGridView1.AllowUserToDeleteRows = false;
            dt=gWBLL.getGWinfo();
            recordCount=dt.Rows.Count;
            pageCount=(recordCount / pageSize); //总页数=总记录数/每页记录数
            if((recordCount % pageSize)>0)
            {
                pageCount++;
            }
            currentPage = 1;
            LoadPage();
        }
        /// 
        /// 加载分页数据
        /// 
        private void LoadPage()
        {
            if (currentPage < 1) currentPage = 1; //如果当前页小于1,则赋值1
            if (currentPage > pageCount) currentPage = pageCount; //如果当前页大于总页数
            int beginRecord; //开始指针
            int endRecord;  //结束指针
            DataTable dtTemp;
            dtTemp = dt.Clone();
            beginRecord = pageSize * (currentPage - 1);
            if (currentPage == 1) beginRecord = 0;
            endRecord = pageSize * currentPage; //总页数乘以当前页

            if (currentPage == pageCount) endRecord = recordCount;
            for (int i = beginRecord; i < endRecord; i++)
            {
                dtTemp.ImportRow(dt.Rows[i]);
            }
            for (int i = 0; i < dtTemp.Rows.Count; i++)
            {
                uiDataGridView1.DataSource = dtTemp;
            }
            DQY.Text = "当前页:" + currentPage.ToString() + "/" + pageCount.ToString(); //当前页
            zhs.Text = "总行数: " + recordCount.ToString() + "行";//总记录数

        }

基于Monster 组和GPT的调写:
把这段代码封装成一个类,然后在需要使用分页的窗体中实例化这个类,调用其中的方法来完成分页功能。
示例

public class Pager
{
    private int pageSize = 30; //每页记录数
    private int recordCount = 0; //总记录数
    private int pageCount = 0; //总页数 
    private int currentPage = 0; //当前页
    private DataTable dataSource = null;

    public Pager(int pageSize, DataTable dataSource)
    {
        this.pageSize = pageSize;
        this.dataSource = dataSource;
        this.recordCount = dataSource.Rows.Count;
        this.pageCount = (recordCount / pageSize); //总页数=总记录数/每页记录数
        if ((recordCount % pageSize) > 0)
        {
            pageCount++;
        }
        currentPage = 1;
    }

    public void LoadPage(int page, DataGridView dataGridView, Label pageLabel, Label recordCountLabel)
    {
        currentPage = page;
        if (currentPage < 1) currentPage = 1; //如果当前页小于1,则赋值1
        if (currentPage > pageCount) currentPage = pageCount; //如果当前页大于总页数
        int beginRecord; //开始指针
        int endRecord; //结束指针
        DataTable dtTemp = dataSource.Clone();
        beginRecord = pageSize * (currentPage - 1);
        if (currentPage == 1) beginRecord = 0;
        endRecord = pageSize * currentPage; //总页数乘以当前页

        if (currentPage == pageCount) endRecord = recordCount;
        for (int i = beginRecord; i < endRecord; i++)
        {
            dtTemp.ImportRow(dataSource.Rows[i]);
        }
        dataGridView.DataSource = dtTemp;
        pageLabel.Text = "当前页:" + currentPage.ToString() + "/" + pageCount.ToString(); //当前页
        recordCountLabel.Text = "总行数: " + recordCount.ToString() + "行";//总记录数
    }
}


在窗体中,你可以实例化这个类并调用它的 LoadPage 方法来实现分页功能。以下是一个示例窗体代码:

public partial class MyForm : Form
{
    private Pager pager;
    public MyForm()
    {
        InitializeComponent();
        pager = new Pager(30, gWBLL.getGWinfo());
        pager.LoadPage(1, uiDataGridView1, DQY, zhs);
    }

    private void btnFirst_Click(object sender, EventArgs e)
    {
        pager.LoadPage(1, uiDataGridView1, DQY, zhs);
    }

    private void btnPrev_Click(object sender, EventArgs e)
    {
        pager.LoadPage(pager.CurrentPage - 1, uiDataGridView1, DQY, zhs);
    }

    private void btnNext_Click(object sender, EventArgs e)
    {
        pager.LoadPage(pager.CurrentPage + 1, uiDataGridView1, DQY, zhs);
    }

    private void btnLast_Click(object sender, EventArgs e)
    {
        pager.LoadPage(pager.PageCount, uiDataGridView1, DQY, zhs);
    }
}


在这个窗体中,我们使用 Pager 类来进行分页。在窗体的构造函数中,我们创建了 Pager 类的一个实例,并调用了它的 LoadPage 方法来加载第一页数据。接下来,我们在按钮的单击事件中调用 LoadPage 方法,该方法会根据当前页码,计算需要加载哪些数据,并将这些数据展示在 UI 中。因此,我们需要在翻页操作(如上一页、下一页、跳转到指定页码)的事件处理程序中修改 currentPage 属性,并再次调用 LoadPage 方法来加载新的数据。

下面是一个简单的示例,假设有两个按钮分别用于向前和向后翻页:

private void btnPreviousPage_Click(object sender, EventArgs e)
{
    currentPage--; // 将当前页码减一
    LoadPage(); // 加载新的数据
}

private void btnNextPage_Click(object sender, EventArgs e)
{
    currentPage++; // 将当前页码加一
    LoadPage(); // 加载新的数据
}
  

你可以在每个按钮的 Click 事件处理程序中修改 currentPage 属性,然后再次调用 LoadPage 方法来加载新的数据。此外,你可能需要在 UI 中添加一个文本框和一个跳转按钮,允许用户输入要跳转到的页码。当用户点击跳转按钮时,你可以从文本框中读取页码,将 currentPage 属性设置为该值,然后再次调用 LoadPage 方法来加载新的数据。

希望这个例子能帮助你更好地理解如何调用分页方法。

该回答引用ChatGPT

您可以将这段代码封装成一个独立的分页控件或者一个分页工具类,然后在需要分页的窗体中调用该控件或者工具类。下面是一个示例:

新建一个名为"PaginationHelper"的类文件,将上述分页代码复制进去,然后将类声明为静态类。


public static class PaginationHelper
{
    public static void LoadPage(DataTable dataTable, DataGridView dataGridView, int pageSize, int currentPage, Label dqy, Label zhs)
    {
        int recordCount = dataTable.Rows.Count;
        int pageCount = (recordCount / pageSize); //总页数=总记录数/每页记录数
        if ((recordCount % pageSize) > 0)
        {
            pageCount++;
        }

        if (currentPage < 1) currentPage = 1; //如果当前页小于1,则赋值1
        if (currentPage > pageCount) currentPage = pageCount; //如果当前页大于总页数

        int beginRecord = pageSize * (currentPage - 1); //开始指针
        int endRecord = Math.Min(beginRecord + pageSize, recordCount);  //结束指针

        DataTable dtTemp = dataTable.Clone();
        for (int i = beginRecord; i < endRecord; i++)
        {
            dtTemp.ImportRow(dataTable.Rows[i]);
        }
        dataGridView.DataSource = dtTemp;

        dqy.Text = "当前页:" + currentPage.ToString() + "/" + pageCount.ToString(); //当前页
        zhs.Text = "总行数: " + recordCount.ToString() + "行"; //总记录数
    }
}


在窗体中调用该静态方法,传入需要分页的DataTable、DataGridView以及其他参数。


private void PageSorter()
{
    uiDataGridView1.AllowUserToAddRows = false;
    uiDataGridView1.AllowUserToDeleteRows = false;

    DataTable dt = gWBLL.getGWinfo();

    int pageSize = 30; //每页记录数
    int currentPage = 1; //当前页

    PaginationHelper.LoadPage(dt, uiDataGridView1, pageSize, currentPage, DQY, zhs);
}

这样,您就可以在其他需要分页的窗体中直接调用该静态方法,从而复用分页代码。需要注意的是,您需要为窗体中的DataGridView控件设置AllowUserToAddRows和AllowUserToDeleteRows属性为false,以防止用户在表格中插入或删除行造成分页错误。

private void BindDataToDataGridView(DataGridView dgv, DataTable dt, int pageSize, int pageIndex)
{
    dgv.DataSource = null;

    // 计算总页数
    int pageCount = (int)Math.Ceiling(dt.Rows.Count / (double)pageSize);

    // 如果 pageIndex 超出范围,则重置为第一页
    if (pageIndex < 1)
    {
        pageIndex = 1;
    }
    else if (pageIndex > pageCount)
    {
        pageIndex = pageCount;
    }

    // 计算要显示的数据的起始和结束索引
    int startIndex = (pageIndex - 1) * pageSize;
    int endIndex = Math.Min(startIndex + pageSize - 1, dt.Rows.Count - 1);

    // 创建一个临时的 DataTable 来保存要显示的数据
    DataTable tempTable = dt.Clone();
    for (int i = startIndex; i <= endIndex; i++)
    {
        tempTable.ImportRow(dt.Rows[i]);
    }

    // 绑定数据到 DataGridView
    dgv.DataSource = tempTable;

    // 显示当前页数和总页数
    lblPageInfo.Text = $"第 {pageIndex} 页,共 {pageCount} 页";
}


C#——DataGridView分页功能的实现
https://www.cnblogs.com/sayu115/archive/2007/10/12/922115.html
借鉴下,挺详细的

参考GPT和自己的思路,可以将DGV分页写成一个方法,然后在需要分页的地方调用这个方法,具体实现代码如下:

public partial class GW_Form : Form
{
    public int pageSize = 30; //每页记录数
    public int recordCount = 0;  //总记录数
    public int pageCount = 0; //总页数 
    public int currentPage = 0; //当前页
    DataTable dt=null;
    GWBLL gWBLL=new GWBLL(); //查询全部数据方法

    // 分页方法
    private void PageSorter(DataGridView dgv, DataTable dt)
    {
        dgv.AllowUserToAddRows = false;
        dgv.AllowUserToDeleteRows = false;
        recordCount=dt.Rows.Count;
        pageCount=(recordCount / pageSize); //总页数=总记录数/每页记录数
        if((recordCount % pageSize)>0)
        {
            pageCount++;
        }
        currentPage = 1;
        LoadPage(dgv, dt);
    }

    /// <summary>
    /// 加载分页数据
    /// </summary>
    private void LoadPage(DataGridView dgv, DataTable dt)
    {
        if (currentPage < 1) currentPage = 1; //如果当前页小于1,则赋值1
        if (currentPage > pageCount) currentPage = pageCount; //如果当前页大于总页数
        int beginRecord; //开始指针
        int endRecord;  //结束指针
        DataTable dtTemp;
        dtTemp = dt.Clone();
        beginRecord = pageSize * (currentPage - 1);
        if (currentPage == 1) beginRecord = 0;
        endRecord = pageSize * currentPage; //总页数乘以当前页

        if (currentPage == pageCount) endRecord = recordCount;
        for (int i = beginRecord; i < endRecord; i++)
        {
            dtTemp.ImportRow(dt.Rows[i]);
        }
        dgv.DataSource = dtTemp;
        DQY.Text = "当前页:" + currentPage.ToString() + "/" + pageCount.ToString(); //当前页
        zhs.Text = "总行数: " + recordCount.ToString() + "行";//总记录数
    }

    // 在需要分页的地方调用 PageSorter 方法
    private void someMethod()
    {
        dt=gWBLL.getGWinfo();
        PageSorter(uiDataGridView1, dt);
    }
}

这样就可以在需要分页的地方调用 PageSorter 方法,把DataGridView和数据表传入,即可实现分页功能。

public void BindDataGridViewWithPaging(DataGridView dgv, DataTable dt, int pageSize, int currentPage)
{
    int recordCount = dt.Rows.Count;
    int pageCount = (recordCount / pageSize) + ((recordCount % pageSize) > 0 ? 1 : 0);

    if (currentPage < 1) currentPage = 1;
    if (currentPage > pageCount) currentPage = pageCount;

    int startIndex = (currentPage - 1) * pageSize;
    int endIndex = Math.Min(startIndex + pageSize, recordCount);

    DataTable dtTemp = dt.Clone();
    for (int i = startIndex; i < endIndex; i++)
    {
        dtTemp.ImportRow(dt.Rows[i]);
    }

    dgv.DataSource = dtTemp;
    dgv.AllowUserToAddRows = false;
    dgv.AllowUserToDeleteRows = false;

    dgv.Columns.Cast<DataGridViewColumn>().ToList().ForEach(c => c.SortMode = DataGridViewColumnSortMode.NotSortable);

    dgv.RowHeadersVisible = false;
    dgv.ReadOnly = true;

    dgv.Refresh();

    if (dgv.Rows.Count > 0)
    {
        dgv.Rows[0].Selected = false;
    }
}

可以参考我的这个文章,来实现winfrom控件的分页