`
yanyanquan
  • 浏览: 452548 次
  • 性别: Icon_minigender_1
  • 来自: 江门
社区版块
存档分类
最新评论

C# Winform DataGridView 公共分页实现

阅读更多

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
        }
分享到:
评论
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);

相关推荐

    C# Winform DatagridView 分页及 全选/ 取消全选 功能

    总之,通过理解并实现`DataGridView`的分页和全选/取消全选功能,你可以提升C# Winform应用的数据管理效率,使得用户在面对大量数据时能更流畅地操作。同时,结合实际项目需求,还可以进一步优化和扩展这些功能,...

    C# winform分页控件,用于dataGridView分页浏览,分页,跳转,自定义页数,动态设置页大小

    C# winform分页控件,用于dataGridView分页浏览 `PageControl`是一个为Windows Forms应用程序提供的自定义用户控件,用于实现数据分页显示功能。该控件允许用户通过简单的界面导航不同的数据页,包括首页、上一页、...

    C# Winform Datagridview 分页和打印功能.pdf

    首先,关于DataGridView分页功能的实现,常用方法是通过自定义分页逻辑来处理。开发者可以通过引入一个分页控件来帮助用户选择页码,或手动控制DataGridView的数据显示,如只显示当前页的数据。分页逻辑需要开发者...

    WinForm下编写分页控件,实现DataGridView的分页效果

    本教程将详细介绍如何在WinForm应用中自定义一个分页控件,以实现`DataGridView`组件的分页查询效果。 首先,我们需要理解`DataGridView`是.NET Framework提供的一种用于展示表格数据的控件,它可以绑定到各种数据...

    C# WinForm ListView,DataGridView通用分页控件

    WinForm ListView,DataGridView通用分页控件,因为自己要用,自己根据网上搜罗的一些代码进行重新封装,文件中有一个PagerNavigate.dll文件,包含了两种分页控件,ListView,DataGridView可以通用任何一个分页控件。...

    C# WinForm Datagridview分页+增删改+导航+导出word-exel

    如题,C# WinForm Datagridview分页+增删改+导航+导出word-exel,代码写的很清楚,有注释。。几乎每句都有。。 mssql数据库自己配置,已打包在内,只消附加数据库,然后更改app.config既可。 调试不出来,或者调试...

    C#DataGridView分页显示功能实现

    本篇文章将详细讲解如何在C# WinForm应用中实现`DataGridView`的分页功能。 首先,我们需要了解`DataGridView`的基本用法。`DataGridView`可以通过编程方式动态添加行,或者绑定到数据源(如DataTable、Binding...

    C#源码Datagridview分页事例

    首先,理解Datagridview分页的基本概念。分页允许用户以较小的数据集浏览数据,而不是一次性加载所有记录,这可以显著减少内存占用并提高程序性能。在C#中,我们可以使用自定义分页逻辑或第三方库来实现这一功能。 ...

    C# winform下的DataGridview分页控件源代码

    标题提到的“C# winform下的DataGridview分页控件源代码”正是这样一个解决方案。 首先,我们来看`Pager.Designer.cs`和`Pager.cs`这两个文件。`Designer.cs`文件通常包含Visual Studio自动生成的控件设计时元数据...

    c#winform datagridview打印整个列表的例子,源码奉上

    以上就是`DataGridView`在C# WinForm中打印的实现方式。通过这些步骤,你可以轻松地将`DataGridView`的数据转换为纸质形式。在实际开发中,可能还需要根据具体需求进行优化,例如添加页眉和页脚、处理大量数据的分页...

    C# winform程序实现分页的方法

    ### C# Winform程序实现分页的方法 在处理大量数据时,一次性加载所有数据到内存中不仅会增加程序的资源占用,还可能导致程序运行效率降低甚至崩溃。因此,实现有效的分页功能对于提升用户体验和系统性能至关重要。...

    C# winform DataGridView 的18种常见属性

    在C# WinForm开发中,`DataGridView`是一个常用的控件,用于展示表格数据。它提供了丰富的功能和灵活性,包括编辑、排序、筛选等。本文将详细介绍`DataGridView`的18种常见属性,帮助开发者更好地理解和利用这个控件...

    winform下datagridview分页控件

    总结来说,在C#的Winform环境下,实现`DataGridView`的分页功能需要结合数据源管理、事件驱动编程以及可能的第三方库。通过合理的数据加载策略和用户交互设计,可以为用户提供高效且直观的数据浏览体验。

    c# winform 打印DataGridView日期数据格式,格式化日期格式,可多页并可选择列打印

    总之,实现C# WinForm中的`DataGridView`打印功能,需要对`PrintDocument`类有深入理解,并掌握日期格式化、分页逻辑和用户选择列的处理。通过分析提供的源码,我们可以学习到实际开发中的最佳实践,提高我们的编程...

    winform漂亮的第三方控件按钮datagridview分页等等

    "winform漂亮的第三方控件按钮datagridview分页等等"这个主题中,我们主要探讨的是如何利用第三方控件增强Windows窗体应用程序的功能和视觉效果。 首先,让我们聚焦在“DataGridView”控件上。系统自带的...

    Winform DataGridView 控件分页控件,上/下一页,跳转(附下载链接)

    Winform DataGridView 控件分页控件,上/下一页,跳转(附下载链接),详情看我的文章介绍:https://blog.csdn.net/m0_65636467/article/details/143773960

    WinForm(C#) DataGridView简单应用示例

    在.NET Framework中,WinForm是用于创建桌面应用程序的用户界面框架,而C#是一种常用的编程语言,两者结合可以实现丰富的图形用户界面(GUI)应用。`DataGridView`控件是WinForm中的一个核心组件,用于展示表格数据...

    WinForm Datagridview 分页 导航 EXICT导出 里面有2套实例程序

    在提供的实例程序中,"C#WinForm-DatagridView-操作-分页-导航实例"很可能是演示了如何实现分页和导航功能的具体代码,你可以通过运行和学习这个例子了解具体实现。另一个文件名"WinPager"可能是一个专门用于分页的...

Global site tag (gtag.js) - Google Analytics