- 浏览: 451109 次
- 性别:
- 来自: 江门
文章分类
最新评论
-
ctz_131415:
谁能告诉我这个分页控件如何添加到窗口上?谢谢了
C# Winform DataGridView 公共分页实现 -
omymy:
FrmPage_Shown是放在页面加载时的load事件里的, ...
C# Winform DataGridView 公共分页实现 -
qie:
如何使用该分页控件?
C# Winform DataGridView 公共分页实现 -
anyanlonga:
看地图干什么用啊,如果查公交的话,自认为还是白度好
Android 上创建和地图相关的应用,用 Google 地图 API 好,还是百度等第三方地图 API 好 -
dedepro:
果然很强。
CSS层 固定置顶部兼容IE6等以上浏览器
Demo的界面
我利用事件委托事件,仿http://www.cnblogs.com/huyong/写的公共分页用户控件
#region 版权信息 /*---------------------------------------------------------------------* // 项目 名称:《Winform分页控件》 // 文 件 名: Pager.cs // 描 述: 分页控件 // 作 者:kwon yan *----------------------------------------------------------------------*/ #endregion using System; using System.Collections.Generic; using System.ComponentModel; using System.Drawing; using System.Data; using System.Linq; using System.Text; using System.Windows.Forms; namespace HuishengFS.Controls { /**/ /// <summary> /// 申明委托 /// </summary> /// <param name="e"></param> /// <returns></returns> public delegate int EventPagingHandler(EventPagingArg e); /**/ /// <summary> /// 分页控件呈现 /// </summary> public partial class Pager : UserControl { public Pager() { InitializeComponent(); } public event EventPagingHandler EventPaging; /**/ /// <summary> /// 每页显示记录数 /// </summary> private int _pageSize = 50; /**/ /// <summary> /// 每页显示记录数 /// </summary> public int PageSize { get { return _pageSize; } set { _pageSize = value; GetPageCount(); } } private int _nMax = 0; /**/ /// <summary> /// 总记录数 /// </summary> public int NMax { get { return _nMax; } set { _nMax = value; GetPageCount(); } } private int _pageCount = 0; /**/ /// <summary> /// 页数=总记录数/每页显示记录数 /// </summary> public int PageCount { get { return _pageCount; } set { _pageCount = value; } } private int _pageCurrent = 0; /**/ /// <summary> /// 当前页号 /// </summary> public int PageCurrent { get { return _pageCurrent; } set { _pageCurrent = value; } } /// <summary> /// 设置页面大小 /// </summary> private void GetPageCount() { if (this.NMax > 0) { this.PageCount = Convert.ToInt32(Math.Ceiling(Convert.ToDouble(this.NMax) / Convert.ToDouble(this.PageSize))); lblPageCount.Text = " / " + PageCount.ToString(); //lblPageCount1.Text = "每页 "+PageSize .ToString ()+" 条,共 "+PageCount.ToString()+" 页"; lblPageCount1.Text = "Page no: " + PageSize.ToString() + ",Total:" + PageCount.ToString() + " pages"; } else { this.PageCount = 0; } } /**/ /// <summary> /// 翻页控件数据绑定的方法 关键是这步,都是调用这里 /// </summary> public void Bind() { if (this.EventPaging != null) { this.NMax = this.EventPaging(new EventPagingArg(this.PageCurrent)); } if (this.PageCurrent > this.PageCount) { this.PageCurrent = this.PageCount; } if (this.PageCount == 1) { this.PageCurrent = 1; } lblcurentpage.Text = PageCurrent.ToString(); //lblRecordCount.Text = "共有 " + NMax.ToString() + " 条记录"; lblRecordCount.Text = "Total: " + NMax.ToString() + " records"; btnPrev.Enabled = true; btnFirst.Enabled = true; btnLast.Enabled = true; btnNext.Enabled = true; if (this.PageCurrent == 1) { this.btnPrev.Enabled = false; this.btnFirst.Enabled = false; } if (this.PageCurrent == this.PageCount) { this.btnLast.Enabled = false; this.btnNext.Enabled = false; } if (this.NMax == 0) { btnNext.Enabled = false; btnLast.Enabled = false; btnFirst.Enabled = false; btnPrev.Enabled = false; } cmbPagecount.Items.Clear(); for (int i = 1; i <= PageCount; i++) cmbPagecount.Items.Add(i.ToString()); cmbPagecount.SelectedIndex = PageCurrent - 1; } /// <summary> /// 首页 /// </summary> /// <param name="sender"></param> /// <param name="e"></param> private void btnFirst_Click(object sender, EventArgs e) { PageCurrent = 1; this.Bind(); } //上一页 /// <summary> /// /// </summary> /// <param name="sender"></param> /// <param name="e"></param> private void btnPrev_Click(object sender, EventArgs e) { PageCurrent -= 1; if (PageCurrent <= 0) { PageCurrent = 1; } this.Bind(); } /// <summary> /// 下一页 /// </summary> /// <param name="sender"></param> /// <param name="e"></param> private void btnNext_Click(object sender, EventArgs e) { this.PageCurrent += 1; if (PageCurrent > PageCount) { PageCurrent = PageCount; } this.Bind(); } /// <summary> /// 最后页 /// </summary> /// <param name="sender"></param> /// <param name="e"></param> private void btnLast_Click(object sender, EventArgs e) { PageCurrent = PageCount; this.Bind(); } /// <summary> /// 转到新页 /// </summary> /// <param name="sender"></param> /// <param name="e"></param> public void btnGo_Click(object sender, EventArgs e) { if (Int32.TryParse(cmbPagecount.SelectedItem.ToString(), out _pageCurrent)) { this.Bind(); } } } /**/ /// <summary> /// 自定义事件数据基类 /// </summary> public class EventPagingArg : EventArgs { private int _intPageIndex; public EventPagingArg(int PageIndex) { _intPageIndex = PageIndex; } } }
前提准备
编写分页的SQL 语句和获取总数的SQL语句
--分页存储过程 也可以SQL语句 --获取总数的语句 我也不必多写了 if exists(select * from sysobjects where name='Proc_DgvPage') drop proc name='Proc_DgvPage') go create proc name='Proc_DgvPage') ( @keyword varchar(100), --关键字 @start varchar(5), @end varchar(5) ) as begin select sortTb.clientCode, sortTb.fileReference,sortTb.clientName1, sortTb.clientName2, sortTb.dateOpen, sortTb.dateClose,sortTb.fileMaster, sortTb.clientTel, sortTb.clientMobile, sortTb.clientFex,sortTb.companyName,sortTb.clientAddr, sortTb.propFlat, sortTb.propFloor, sortTb.propBlock, sortTb.propBuilding, sortTb.propStree, sortTb.propDistrict, sortTb.propArea, sortTb.isFileClosed from ( select row_number() over(order by c.clientCode) as sortNo, c.clientCode, f.fileSubpervisor+''/''+f.fileCode+''/''+f.fileYear+''/''+f.fileIntro+''/''+f.fileHandler as fileReference, c.clientLastName1+'' ''+c.clientFirstName1 as clientName1, c.clientLastName2+'' ''+c.clientFirstName2 as clientName2,f.dateOpen, f.dateClose,f.fileMaster, c.clientTel, c.clientMobile, c.clientFex,c.companyName,c.clientAddr, f.propFlat, f.propFloor, f.propBlock, f.propBuilding, f.propStree, f.propDistrict, f.propArea, f.isFileClosed from clientInfo c left join clientFiles f on c.clientCode = f.fileCode where 1=1 ) as sortTb where sortNo between @start and @end end go
在窗体调用:
//定义变量 DataTable dtPage; /// <summary> /// GridViw数据绑定 /// </summary> /// <returns></returns> private int BindDgv() { //传入要取的第一条和最后一条 string start = (pager1.PageSize * (pager1.PageCurrent - 1) + 1).ToString(); string end = (pager1.PageSize * pager1.PageCurrent).ToString(); //数据源 dtPage = achieve.GetAll(Keyword, start, end); //绑定分页控件 pager1.bindingSource1.DataSource = dtPage; pager1.bindingNavigator1.BindingSource = pager1.bindingSource1; //讲分页控件绑定DataGridView dgvClients.DataSource = pager1.bindingSource1; //返回总记录数 return achieve.GetToalCount(Keyword); } /// <summary> /// 分页控件产生的事件 /// </summary> private int pager1_EventPaging(HuishengFS.Controls.EventPagingArg e) { return DgvBind(); } /// <summary> /// 加载分页 或许写在Load事件里面 /// </summary> private void FrmPage_Shown(object sender, EventArgs e) { #region DataGridView与Pager控件绑定 this.pager1.PageCurrent = 1;//当前页为第一页 pager1.PageSize = 100;//页数 this.pager1.Bind();//绑定 #endregion }
- UcControl.rar (7.5 KB)
- 下载次数: 1667
评论
6 楼
ctz_131415
2015-08-19
谁能告诉我这个分页控件如何添加到窗口上?谢谢了
5 楼
omymy
2014-08-18
FrmPage_Shown是放在页面加载时的load事件里的,在页面编辑器里设置属性PageCurrent 和PageSize也是可以的,但pager1.Bind();一定要加上
4 楼
qie
2013-12-23
如何使用该分页控件?
3 楼
yanyanquan
2012-02-09
luitao 写道
能否说如何添加到其它窗体上使用啊?
你保存那个文件后,你直接拖过去就行了。
2 楼
luitao
2012-02-06
能否说如何添加到其它窗体上使用啊?
1 楼
feiniao0822
2011-10-20
很好的文章。谢谢分享。
补充一下。FrmPage_Shown事件中(一般用load事件)需要绑定事件
代码如下:
pager1.EventPaging += new HuishengFS.Controls.EventPagingHandler(pager1_EventPaging);
补充一下。FrmPage_Shown事件中(一般用load事件)需要绑定事件
代码如下:
pager1.EventPaging += new HuishengFS.Controls.EventPagingHandler(pager1_EventPaging);
发表评论
-
Active Server Pages 错误 'ASP 0131'解决方法
2013-07-10 12:09 953在Windows Server 2003中默认情况下是没有启 ... -
asp.net 导出html到doc文件
2012-02-09 09:40 1101/// <summary> /// 导 ... -
C# 如何在textbox里显示txt文件的内容
2012-01-21 15:45 3092//如何在textbox里显示txt文件的内容 ... -
WPF与WinForm的抉择
2011-11-10 17:13 19618微软曾经对WPF(代号Avalon)抱很大的期望——新一代的华 ... -
IIS Ceb文件允许下载
2011-09-02 14:24 1165IIS设置 拓展名:.ceb 类型:appli ... -
C# 日常处理时间函数
2011-09-01 11:08 9081 DateTime.DaysInMonth //获取一个月 ... -
c# 学习的网址
2011-08-19 10:50 885c# 学习的网址 1.参考:http://msdn.m ... -
C# 公共连接数据处理类
2011-08-10 10:15 1111以下的公共类,处理连接打开与关闭,有增删查改,无论SQL语句或 ... -
C# Winform 反射调用打开窗体
2011-07-23 12:08 7710/// <summary> /// ... -
C# Winform 修改app.config文件
2011-07-15 15:48 2924<?xml version="1.0" ... -
C# RDLC开发备忘录
2011-07-09 09:33 18761.PageHeader区域不能放Table、List控件,如 ... -
C# Winform Combobox手动绑定数据
2011-07-05 15:29 2405定义一个类,有两个属性public class ValueOb ... -
C# Winform 读取XML以及修改
2011-06-28 18:10 3691在调用方法之前,要右击选中的xml文件,设置xml 的 Coy ... -
ASP.NET XML读取、增加、修改和删除操作
2011-06-28 16:36 4084C#—XML读取、增加、修改和删除操作 1.xml文件格式 ... -
C# Winform ReportView绑定数据
2011-06-28 14:34 2750.net frame work 3.5 ReportView1 ... -
C# Winform DataGridView单元格合并
2011-06-24 11:09 5260需要重绘单元格。在下面这个事件里写就可以了,下面这个例子只是对 ... -
C# winform 窗体定义功能快捷键
2011-06-20 16:11 4032这里的快捷键并非系统全局快捷键。仅是普通的当窗体在焦点内是发生 ... -
C# Winform 窗体传值的几种方法
2011-06-14 18:26 4046窗体传值的几种方法: 1.使用公共类 在项目中建一User ... -
C# Winform 窗体间传值
2011-06-14 18:23 1452在窗体form1的窗体 在button1的单击事件中写入如下 ... -
C# Winform 直接操作DataGridView,添加列 添加行 操作
2011-06-09 10:58 21862//Datagridview添加列 DataGridVi ...
相关推荐
总之,通过理解并实现`DataGridView`的分页和全选/取消全选功能,你可以提升C# Winform应用的数据管理效率,使得用户在面对大量数据时能更流畅地操作。同时,结合实际项目需求,还可以进一步优化和扩展这些功能,...
首先,关于DataGridView分页功能的实现,常用方法是通过自定义分页逻辑来处理。开发者可以通过引入一个分页控件来帮助用户选择页码,或手动控制DataGridView的数据显示,如只显示当前页的数据。分页逻辑需要开发者...
本教程将详细介绍如何在WinForm应用中自定义一个分页控件,以实现`DataGridView`组件的分页查询效果。 首先,我们需要理解`DataGridView`是.NET Framework提供的一种用于展示表格数据的控件,它可以绑定到各种数据...
WinForm ListView,DataGridView通用分页控件,因为自己要用,自己根据网上搜罗的一些代码进行重新封装,文件中有一个PagerNavigate.dll文件,包含了两种分页控件,ListView,DataGridView可以通用任何一个分页控件。...
如题,C# WinForm Datagridview分页+增删改+导航+导出word-exel,代码写的很清楚,有注释。。几乎每句都有。。 mssql数据库自己配置,已打包在内,只消附加数据库,然后更改app.config既可。 调试不出来,或者调试...
本篇文章将详细讲解如何在C# WinForm应用中实现`DataGridView`的分页功能。 首先,我们需要了解`DataGridView`的基本用法。`DataGridView`可以通过编程方式动态添加行,或者绑定到数据源(如DataTable、Binding...
首先,理解Datagridview分页的基本概念。分页允许用户以较小的数据集浏览数据,而不是一次性加载所有记录,这可以显著减少内存占用并提高程序性能。在C#中,我们可以使用自定义分页逻辑或第三方库来实现这一功能。 ...
标题提到的“C# winform下的DataGridview分页控件源代码”正是这样一个解决方案。 首先,我们来看`Pager.Designer.cs`和`Pager.cs`这两个文件。`Designer.cs`文件通常包含Visual Studio自动生成的控件设计时元数据...
以上就是`DataGridView`在C# WinForm中打印的实现方式。通过这些步骤,你可以轻松地将`DataGridView`的数据转换为纸质形式。在实际开发中,可能还需要根据具体需求进行优化,例如添加页眉和页脚、处理大量数据的分页...
### C# Winform程序实现分页的方法 在处理大量数据时,一次性加载所有数据到内存中不仅会增加程序的资源占用,还可能导致程序运行效率降低甚至崩溃。因此,实现有效的分页功能对于提升用户体验和系统性能至关重要。...
在C# WinForm开发中,`DataGridView`是一个常用的控件,用于展示表格数据。它提供了丰富的功能和灵活性,包括编辑、排序、筛选等。本文将详细介绍`DataGridView`的18种常见属性,帮助开发者更好地理解和利用这个控件...
总结来说,在C#的Winform环境下,实现`DataGridView`的分页功能需要结合数据源管理、事件驱动编程以及可能的第三方库。通过合理的数据加载策略和用户交互设计,可以为用户提供高效且直观的数据浏览体验。
总之,实现C# WinForm中的`DataGridView`打印功能,需要对`PrintDocument`类有深入理解,并掌握日期格式化、分页逻辑和用户选择列的处理。通过分析提供的源码,我们可以学习到实际开发中的最佳实践,提高我们的编程...
"winform漂亮的第三方控件按钮datagridview分页等等"这个主题中,我们主要探讨的是如何利用第三方控件增强Windows窗体应用程序的功能和视觉效果。 首先,让我们聚焦在“DataGridView”控件上。系统自带的...
Winform DataGridView 控件分页控件,上/下一页,跳转(附下载链接),详情看我的文章介绍:https://blog.csdn.net/m0_65636467/article/details/143773960
在.NET Framework中,WinForm是用于创建桌面应用程序的用户界面框架,而C#是一种常用的编程语言,两者结合可以实现丰富的图形用户界面(GUI)应用。`DataGridView`控件是WinForm中的一个核心组件,用于展示表格数据...
在提供的实例程序中,"C#WinForm-DatagridView-操作-分页-导航实例"很可能是演示了如何实现分页和导航功能的具体代码,你可以通过运行和学习这个例子了解具体实现。另一个文件名"WinPager"可能是一个专门用于分页的...
在C# WinForm开发中,`DataGridView`是一个非常重要的控件,它用于显示表格数据,支持多种操作,如浏览、编辑、排序、分页等。本文将深入探讨`DataGridView`的使用方法,以及如何将其与XML数据源绑定,并实现分页...