我自己之前边学边搞了个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控件的分页