说明:(1)如果对分页的感兴趣的话,可以看一下我传的存储过程(“SQL 存储过程 分页”)  

            (2)分页,第一页、上一页,下一页、最后一页只调用点击(click)事件即可;如果想要实用性的好的话,txtNowPage,需              要调用3个事件,点击事件(click)、离开事件(leave)、目标按下事件(keypress)。

效果图:



代码实现如下:

public void DataBind()

{

            #region 数据绑定

            GetWhere();

            object[] page = new object[8];

            page[0] = "表或视图";

            page[1] = " 字段名称 ";

            page[2] = pagesize;//没有多少条记录

            page[3] = nowpage;//当前页码

            page[4] = strWhere;//查询条件

            page[5] = "表的主键";

            page[6] = sumpage;//总页数

            page[7] = sizecount;//总条数

            DataSet dset = new DataSet();

            dset = DataAccess.GetDataSet("P_Public_Paging", true, page);

            dgvMainTop.DataSource = dset.Tables[0];

            sumpage = Convert.ToInt32(dset.Tables[1].Rows[0][0].ToString());

            sizecount = Convert.ToInt32(dset.Tables[1].Rows[0][1].ToString());           

            lblSumCount.Text = "(共" + sizecount + "条记录)";

            txtNowPage.Text = nowpage + "/" + sumpage;

            PageState();           //分页状态

}

private void PageState()

        {

            #region  分页按钮状态

            if (sumpage <= 1)

            {

                btnUp.Enabled = false;

                btnNext.Enabled = false;

                btnFirst.Enabled = false;

                btnEnd.Enabled = false;

            }

            else

            {

                if (nowpage == 1)

                {

                    btnFirst.Enabled = false;

                    btnEnd.Enabled = true;

                    btnUp.Enabled = false;

                    btnNext.Enabled = true;

                }

                else if (nowpage == sumpage)

                {

                    btnUp.Enabled = true;

                    btnNext.Enabled = false;

                    btnFirst.Enabled = true;

                    btnEnd.Enabled = false;

                }

                else

                {

                    btnUp.Enabled = true;

                    btnNext.Enabled = true;

                    btnFirst.Enabled = true;

                    btnEnd.Enabled = true;

                }

            }

            #endregion

        }



        private void btnFirst_Click(object sender, EventArgs e)

        {

            #region  第一页按钮事件

            DataBind();

            #endregion

        }



        private void btnUp_Click(object sender, EventArgs e)

        {

            #region 上一页按钮事件

            nowpage--;

            DataBind();

            #endregion

        }



        private void btnNext_Click(object sender, EventArgs e)

        {

            #region 下一页按钮事件

            nowpage++;

            DataBind();

            #endregion

        }



        private void btnEnd_Click(object sender, EventArgs e)

        {

            #region  最后一页按钮事件

            nowpage = sumpage;

            DataBind();

            #endregion

        }



        private void txtNowPage_KeyPress(object sender, KeyPressEventArgs e)

        {

            #region 页码输入限制,允许输入0-9数字 回退键  回车键

            e.Handled = true;

            if (e.KeyChar >= '0' && e.KeyChar <= '9' || e.KeyChar == 8)

            {

                e.Handled = false;

            }

            if (e.KeyChar == 13)

            {

                btnFind.Focus();

            }

            #endregion

        }



        private void txtNowPage_Leave(object sender, EventArgs e)

        {

            #region 设置当前页 最大为总页数 最小1

            if (txtNowPage.Text == string.Empty)

            {

                nowpage = 1;

                txtNowPage.Text = nowpage + "/" + sumpage;

            }

            string strpage = txtNowPage.Text.Trim();

            string[] array = strpage.Split('/');

            txtNowPage.Text = array[0];

            int page = int.Parse(array[0]);



            if (page <= 1)

            {

                nowpage = 1;

                txtNowPage.Text = nowpage + "/" + sumpage;

            }

            if (page > sumpage)

            {

                nowpage = sumpage;

                txtNowPage.Text = nowpage + "/" + sumpage;

            }

            if (page > 1 && page <= sumpage)

            {

                nowpage = page;

            }

            DataBind();

            #endregion

        }



        private void txtNowPage_Click(object sender, EventArgs e)

        {

            #region  单击页码文本框

            string strpage = txtNowPage.Text.Trim();

            string[] array = strpage.Split('/');

            txtNowPage.Text = array[0];

            txtNowPage.Focus();

            txtNowPage.SelectAll();

            #endregion

        }

版权声明:本文为博主原创文章,未经博主允许不得转载。

winform 分页 分类: WinForm 2014-05-16 15:30 257人阅读 评论(0) 收藏的更多相关文章

  1. SQL 存储过程 分页 分类: SQL Server 2014-05-16 15:11 449人阅读 评论(0) 收藏

    set ANSI_NULLS ON set QUOTED_IDENTIFIER ON go -- ============================================= -- Au ...

  2. PIE(二分) 分类: 二分查找 2015-06-07 15:46 9人阅读 评论(0) 收藏

    Pie Time Limit: 5000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) Total Submissio ...

  3. Find The Multiple 分类: 搜索 POJ 2015-08-09 15:19 3人阅读 评论(0) 收藏

    Find The Multiple Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 21851 Accepted: 8984 Sp ...

  4. 周赛-DZY Loves Chessboard 分类: 比赛 搜索 2015-08-08 15:48 4人阅读 评论(0) 收藏

    DZY Loves Chessboard time limit per test 1 second memory limit per test 256 megabytes input standard ...

  5. Ultra-QuickSort 分类: POJ 排序 2015-08-03 15:39 2人阅读 评论(0) 收藏

    Ultra-QuickSort Time Limit: 7000MS   Memory Limit: 65536K Total Submissions: 48111   Accepted: 17549 ...

  6. Drainage Ditches 分类: POJ 图论 2015-07-29 15:01 7人阅读 评论(0) 收藏

    Drainage Ditches Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 62016 Accepted: 23808 De ...

  7. max_flow(Dinic) 分类: ACM TYPE 2014-09-02 15:42 94人阅读 评论(0) 收藏

    #include <cstdio> #include <iostream> #include <cstring> #include<queue> #in ...

  8. SQL 分组 加列 加自编号 自编号限定 分类: SQL Server 2014-11-25 15:41 283人阅读 评论(0) 收藏

    说明: (1)日期以年月形式显示:convert(varchar(7),字段名,120) , (2)加一列 (3)自编号: row_number() over(order by 字段名 desc) a ...

  9. SQL 按月统计(两种方式) 分类: SQL Server 2014-08-04 15:36 154人阅读 评论(0) 收藏

    (1)Convert 函数 select Convert ( VARCHAR(7),ComeDate,120) as Date ,Count(In_code) as 单数,Sum(SumTrueNum ...

随机推荐

  1. 【POJ1811】【miller_rabin + pollard rho + 快速乘】Prime Test

    Description Given a big integer number, you are required to find out whether it's a prime number. In ...

  2. 那些年优秀的HTML5活动页面

    一个好的手机活动宣传 更能让人分享 传播是爆炸性的 下面是我平时看到一些好的微信活动宣传页面  分享给大家 其中用到的技术 常做微信活动 专题页面的人 可以看看大神们是怎么做的  这样到自己做的时候 ...

  3. secureCRT使用小贴士

    (一)使用WIN键盘 在securecrt界面:工具→键映射编辑器,在弹出的键盘中点击“home”,会弹出一个窗口,在“发送字符串”中输入:\033[1~ 另存为securecrt安装根目录下的Key ...

  4. 【C语言】中的stdbool.h头文件

    C语言中的stdbool.h头文件 一.相关基础知识 二.具体内容 Win7下安装的VS2015中的stdbool.h的位置为: F:\Program Files (x86)\Microsoft Vi ...

  5. Bluestacks 安卓模拟器利器

    蓝手指测试安卓比较给力,尤其含有安卓原生态的多语言是现在厂商手机所无法提供了的.   但是有一点需要注意:BlueStack的日志文件非常大,日志目录默认是%Sysem Dir%/Program Da ...

  6. JSON和XML的比较

    整理日: 2015/4/5 ◆可读性 JSON和XML的可读性可谓不相上下,一边是简易的语法,一边是规范的标签形式,很难分出胜负. ◆可扩展性 XML天生有很好的扩展性,JSON当然也有,没有什么是X ...

  7. golang开发android环境搭建_window

    golang开发android环境搭建介绍 一 安装依赖软件: git:版本管理 go:  go开发环境(版本>=1.5),可直接下载window版的go安装包. android studio: ...

  8. “未能加载文件或程序集file:///E:/MoneySet.dll或它的某一个依赖项,试图加载格式不正确的程序,行203,位置5. 文件:MReportSet.resx”,

    http://bbs.csdn.net/topics/390334265 1.右键卸载项目2.右键选择编辑工程文件,在打开的文件的最后一行</project>之前加以下内容: <Pr ...

  9. IIs工作原理

    http://www.cnblogs.com/szhy222/archive/2008/07/14/1242576.html 问题: HTTP.SYS 的内置驱动程序 IIS 工作者进程

  10. 线性表之顺序存储结构(C语言动态数组实现)

    线性表的定义:N个数据元素的有限序列 线性表从存储结构上分为:顺序存储结构(数组)和 链式存储结构(链表) 顺序存储结构:是用一段连续的内存空间存储表中的数据 L=(a1,a2,a3....an) 链 ...