1. 程式人生 > >C# Winform DataGridView 公共分頁實現

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
        }