DataGridView使用自定义控件实现简单分页功能
本例子使用自定义控件方法实现,数据库使用的是SQL Server,实现过程如下:
1、新建一个自定义控件,命名为:PageControl。

2、PageControl代码如下:
public partial class PageControl : UserControl
{
//委托及事件
public delegate void BindPage(int pageSize, int pageIndex, out int totalCount);
public event BindPage BindPageEvent; //属性
public int PageSize { get; set; } = ; //每页显示记录数
public int PageIndex { get; set; } //页序号
public int TotalCount { get; set; } //总记录数 public int PageCount { get; set; } //总页数 public PageControl()
{
InitializeComponent(); //取消下划线
linkFirst.LinkBehavior = LinkBehavior.NeverUnderline;
linkPrev.LinkBehavior = LinkBehavior.NeverUnderline;
linkNext.LinkBehavior = LinkBehavior.NeverUnderline;
linkLast.LinkBehavior = LinkBehavior.NeverUnderline;
linkGo.LinkBehavior = LinkBehavior.NeverUnderline;
} /// <summary>
/// 设置页
/// </summary>
public void SetPage()
{
//总记录数
int totalCount = ;
BindPageEvent(PageSize, PageIndex + , out totalCount);
TotalCount = totalCount; //总页数
if (TotalCount % PageSize == )
PageCount = TotalCount / PageSize;
else
PageCount = TotalCount / PageSize + ; //当前页及总页数
txtCurrentPage.Text = (PageIndex + ).ToString();
lblTotalPage.Text = "共 " + PageCount.ToString() + " 页";
} /// <summary>
/// 首页
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
private void linkFirst_LinkClicked(object sender, LinkLabelLinkClickedEventArgs e)
{
if (e.Button == MouseButtons.Left)
{
PageIndex = ;
SetPage();
}
} /// <summary>
/// 上一页
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
private void linkPrve_LinkClicked(object sender, LinkLabelLinkClickedEventArgs e)
{
if (e.Button == MouseButtons.Left)
{
PageIndex--;
if (PageIndex < )
{
PageIndex = ;
}
SetPage();
}
} /// <summary>
/// 下一页
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
private void linkNext_LinkClicked(object sender, LinkLabelLinkClickedEventArgs e)
{
if (e.Button == MouseButtons.Left)
{
PageIndex++;
if (PageIndex > PageCount - )
{
PageIndex = PageCount - ;
}
SetPage();
}
} /// <summary>
/// 末页
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
private void linkLast_LinkClicked(object sender, LinkLabelLinkClickedEventArgs e)
{
if (e.Button == MouseButtons.Left)
{
PageIndex = PageCount - ;
SetPage();
}
} /// <summary>
/// 只能按0-9、Delete、Enter、Backspace键
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
private void txtSetPage_KeyPress(object sender, KeyPressEventArgs e)
{
if ((e.KeyChar >= && e.KeyChar <= ) || e.KeyChar == || e.KeyChar == || e.KeyChar == )
{
e.Handled = false;
if (e.KeyChar == )
{
Go();
}
}
else
{
e.Handled = true;
}
} /// <summary>
/// 指定页
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
private void linkGo_LinkClicked(object sender, LinkLabelLinkClickedEventArgs e)
{
if (e.Button == MouseButtons.Left)
{
Go();
}
} private void Go()
{
if (string.IsNullOrEmpty(txtCurrentPage.Text))
{
MessageBox.Show("指定页不能为空。", "提示", MessageBoxButtons.OK, MessageBoxIcon.Information);
txtCurrentPage.Focus();
return;
} if (int.Parse(txtCurrentPage.Text) > PageCount)
{
MessageBox.Show("指定页已超过总页数。", "提示", MessageBoxButtons.OK, MessageBoxIcon.Information);
txtCurrentPage.Focus();
return;
} PageIndex = int.Parse(txtCurrentPage.Text) - ;
SetPage();
} /// <summary>
/// linkFirst鼠标移过颜色
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
private void linkFirst_MouseMove(object sender, MouseEventArgs e)
{
linkFirst.LinkColor = Color.Red;
} /// <summary>
/// linkFirst鼠标离开颜色
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
private void linkFirst_MouseLeave(object sender, EventArgs e)
{
linkFirst.LinkColor = Color.Black;
} /// <summary>
/// linkPrev鼠标移过颜色
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
private void linkPrev_MouseMove(object sender, MouseEventArgs e)
{
linkPrev.LinkColor = Color.Red;
} /// <summary>
/// linkPrev鼠标离开颜色
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
private void linkPrev_MouseLeave(object sender, EventArgs e)
{
linkPrev.LinkColor = Color.Black;
} /// <summary>
/// linkNext鼠标移过颜色
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
private void linkNext_MouseMove(object sender, MouseEventArgs e)
{
linkNext.LinkColor = Color.Red;
} /// <summary>
/// linkNext鼠标离开颜色
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
private void linkNext_MouseLeave(object sender, EventArgs e)
{
linkNext.LinkColor = Color.Black;
} /// <summary>
/// linkLast鼠标移过颜色
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
private void linkLast_MouseMove(object sender, MouseEventArgs e)
{
linkLast.LinkColor = Color.Red;
} /// <summary>
/// linkLast鼠标离开颜色
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
private void linkLast_MouseLeave(object sender, EventArgs e)
{
linkLast.LinkColor = Color.Black;
} /// <summary>
/// linkGo鼠标移过颜色
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
private void linkGo_MouseMove(object sender, MouseEventArgs e)
{
linkGo.LinkColor = Color.Red;
} /// <summary>
/// linkGo鼠标离开颜色
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
private void linkGo_MouseLeave(object sender, EventArgs e)
{
linkGo.LinkColor = Color.Black;
}
}
3、SQL Server创建存储过程PageTest:
CREATE PROCEDURE [dbo].[PageTest]
@PageSize INT,
@PageIndex INT,
@TotalCount INT OUTPUT
AS
BEGIN
--总记录数
SELECT @TotalCount=COUNT(1) FROM MF_MO --记录返回(使用动态SQL绕开参数嗅探问题,效率大幅度提升。)
DECLARE @SQL NVARCHAR(1000)
SET @SQL=
'SELECT TOP ('+CONVERT(VARCHAR(32),@PageSize)+') MO_NO,MRP_NO,QTY,BIL_NO '+
'FROM MF_MO A '+
'WHERE NOT EXISTS (SELECT 1 FROM (SELECT TOP ('+CONVERT(VARCHAR(32),(@PageIndex-1)*@PageSize)+') MO_NO FROM MF_MO ORDER BY MO_NO) B WHERE A.MO_NO=B.MO_NO) '+
'ORDER BY MO_NO'
EXEC (@SQL)
END
4、新建一个WinForm程序,命名为Main,并拖入一个DataGridView控件及上面新建的PageControl控件,代码如下:
private void Main_Load(object sender, EventArgs e)
{
pageControl1.PageSize = ;
pageControl1.PageIndex = ;
pageControl1.BindPageEvent += BindPage;
pageControl1.SetPage();
} /// <summary>
/// 绑定页
/// </summary>
/// <param name="pageSize">每页显示记录数</param>
/// <param name="pageIndex">页序号</param>
/// <param name="totalCount">总记录数</param>
private void BindPage(int pageSize, int pageIndex, out int totalCount)
{
SqlConnection conn = null;
SqlCommand cmd = null;
totalCount = ; #region 连接数据库测试
try
{
//数据库连接
conn = new SqlConnection("server=.;database=DB_TEST;Uid=sa;pwd=********;");
conn.Open(); //SqlCommand
cmd = new SqlCommand();
cmd.Connection = conn;
cmd.CommandText = "PageTest";
cmd.CommandType = CommandType.StoredProcedure; SqlParameter[] param =
{
new SqlParameter("@PageSize",SqlDbType.Int),
new SqlParameter("@PageIndex",SqlDbType.Int),
new SqlParameter("@TotalCount",SqlDbType.Int)
};
param[].Value = pageSize;
param[].Value = pageIndex;
param[].Direction = ParameterDirection.Output;
cmd.Parameters.AddRange(param); //DataTable
DataTable dt = new DataTable("MF_MO");
dt.Columns.Add(new DataColumn("MO_NO", typeof(String)));
dt.Columns.Add(new DataColumn("MRP_NO", typeof(String)));
dt.Columns.Add(new DataColumn("QTY", typeof(Decimal)));
dt.Columns.Add(new DataColumn("BIL_NO", typeof(String))); #region 方法一:SqlDataReader
SqlDataReader dr = cmd.ExecuteReader();
dt.Load(dr, LoadOption.PreserveChanges);
dr.Close();
totalCount = (int)param[].Value;
dataGridView1.DataSource = dt;
#endregion #region #方法二:SqlDataAdapter
//SqlDataAdapter da = new SqlDataAdapter();
//da.SelectCommand = cmd;
//dt.BeginLoadData();
//da.Fill(dt);
//dt.EndLoadData();
//totalCount = (int)param[2].Value;
//dataGridView1.DataSource = dt;
#endregion
}
catch (Exception ex)
{
MessageBox.Show(ex.Message, "提示", MessageBoxButtons.OK, MessageBoxIcon.Information);
}
finally
{
conn.Close();
cmd.Dispose();
}
#endregion
}
5、执行程序:

好了,分享就到此结束了,希望对有此需要的人有一些帮助。
DataGridView使用自定义控件实现简单分页功能的更多相关文章
- DataGridView使用BindingNavigator实现简单分页功能
接上一篇<DataGridView使用自定义控件实现简单分页功能>,本篇使用BindingNavigator来实现简单分页功能.其实也只是借用了一个BindingNavigator空壳, ...
- jQuery实现的简单分页功能的详细解析
分页功能在项目开发中不可或缺,老司机操作起来就和呼吸一样简单,新手恐怕就会吃力一些. 今天我回顾了一下具体的操作步骤,决定详细的分析一下每一步的实现目的及原理. 我们会创建一个简单的json文件来模拟 ...
- Django实现简单分页功能
使用django的第三方模块django-pure-pagination 安装模块: pip install django-pure-pagination 将'pure_pagination'添加到s ...
- winform中DataGridView实现分页功能
WinForm轻松实现自定义分页 (转载) WinForm轻松实现自定义分页 (转载) 转载至http://xuzhihong1987.blog.163.com/blog/static/26731 ...
- 简单封装分页功能pageView.js
分页是一个很简单,通用的功能.作为一个有经验的前端开发人员,有义务把代码中类似这样公共的基础性的东西抽象出来,一来是改善代码的整体质量,更重要的是为了将来做类似的功能或者类似的项目,能减少不必要的重复 ...
- 利用Bootstrap Paginator插件和KnockoutJS完成分页功能
在最近一个项目中,需要结合一堆条件查询并对查询的结果数据完成一个简单分页功能,可是做着做着,自己的思路越来越模糊,做到心态崩溃!!! 哈哈,特此花点时间重新总结,并从最简单的分页,然后向多条件查询分页 ...
- MVC001之mvcpager简单分页
描述:用mvcpager实现简单分页功能 参考网址: http://www.cnblogs.com/iamlilinfeng/archive/2013/03/11/2951460.html http: ...
- C#设计模式总结 C#设计模式(22)——访问者模式(Vistor Pattern) C#设计模式总结 .NET Core launch.json 简介 利用Bootstrap Paginator插件和knockout.js完成分页功能 图片在线裁剪和图片上传总结 循序渐进学.Net Core Web Api开发系列【2】:利用Swagger调试WebApi
C#设计模式总结 一. 设计原则 使用设计模式的根本原因是适应变化,提高代码复用率,使软件更具有可维护性和可扩展性.并且,在进行设计的时候,也需要遵循以下几个原则:单一职责原则.开放封闭原则.里氏代替 ...
- php对文本文件进行分页功能简单实现
php对文本文件进行分页功能简单实现 <!DOCTYPE> <html> <head> <meta http-equiv="Content-type ...
随机推荐
- ef6+mysql的bug
entityFramework6在mysql数据库下,用linq进行排序会出现一个bug. Expression<Func<blog, bool>> expr_filter=p ...
- Python基础之升级pip版本
使用python -m pip install --upgrade pip命令即可. 查看是否更新成功: 使用pip3 list命令即可.
- mysql数据库命令
删除一个表: drop table if exists 表名; 在表中插入行: Insert into 表名 values(, , ,) 创建表: Create table 表名( Id int(10 ...
- luogu P2401 不等数列 |动态规划
题目描述 将1到n任意排列,然后在排列的每两个数之间根据他们的大小关系插入">"和"<".问在所有排列中,有多少个排列恰好有k个"< ...
- JS的引入方式_变量的使用_变量的类型
JS的俩种引入方式: 1. <!--js的引入方式1--> <script> /*网页中的弹框*/ alert("js的学习!!") </script ...
- BZOJ 1051: [HAOI2006]受欢迎的牛(SCC)
1051: [HAOI2006]受欢迎的牛 Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 8172 Solved: 4470[Submit][Sta ...
- 【docker】Dockerfile
[docker]Dockerfile 转载: ============================================================= =============== ...
- 2019年JVM面试都问了什么?快看看这22道面试题!(附答案解析)
一. Java 类加载过程? Java 类加载需要经历一下 7 个过程: 1. 加载 加载是类加载的第一个过程,在这个阶段,将完成一下三件事情: • 通过一个类的全限定名获取该类的二进制流. • 将该 ...
- android studio 项目生成的apk变小的原因
问题:感觉直接在apk文件夹下面拷出来的apk不能安装使用,而且apk比较小,可能就是这个问题引起的 Android Studio版本升级到2.3后,增加了instant run功能,对项目的buil ...
- 最简单的 Java内存模型 讲解
前言 在网上看了很多文章,也看了好几本书中关于JMM的介绍,我发现JMM确实是Java中比较难以理解的概念.网上很多文章中关于JMM的介绍要么是照搬了一些书上的内容,要么就干脆介绍的就是错的.本文试着 ...