中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

怎么在DataGridView中使用自定義控件實現一個分頁功能

發布時間:2021-03-23 15:32:04 來源:億速云 閱讀:427 作者:Leah 欄目:開發技術

今天就跟大家聊聊有關怎么在DataGridView中使用自定義控件實現一個分頁功能,可能很多人都不太了解,為了讓大家更加了解,小編給大家總結了以下內容,希望大家根據這篇文章可以有所收獲。

實現過程如下:

    1、新建一個自定義控件,命名為:PageControl。

怎么在DataGridView中使用自定義控件實現一個分頁功能

    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; } = 1; //每頁顯示記錄數
    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 = 0;
      BindPageEvent(PageSize, PageIndex + 1, out totalCount);
      TotalCount = totalCount;
      //總頁數
      if (TotalCount % PageSize == 0)
        PageCount = TotalCount / PageSize;
      else
        PageCount = TotalCount / PageSize + 1;
      //當前頁及總頁數
      txtCurrentPage.Text = (PageIndex + 1).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 = 0;
        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 < 0)
        {
          PageIndex = 0;
        }
        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 - 1)
        {
          PageIndex = PageCount - 1;
        }
        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 - 1;
        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 >= 48 && e.KeyChar <= 57) || e.KeyChar == 8 || e.KeyChar == 13 || e.KeyChar == 127)
      {
        e.Handled = false;
        if (e.KeyChar == 13)
        {
          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) - 1;
      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 = 20;
      pageControl1.PageIndex = 0;
      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 = 0;
      #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[0].Value = pageSize;
        param[1].Value = pageIndex;
        param[2].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[2].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
    }

看完上述內容,你們對怎么在DataGridView中使用自定義控件實現一個分頁功能有進一步的了解嗎?如果還想了解更多知識或者相關內容,請關注億速云行業資訊頻道,感謝大家的支持。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

余庆县| 股票| 遂川县| 吕梁市| 石首市| 苏尼特右旗| 仪陇县| 南充市| 井研县| 合水县| 温泉县| 佛坪县| 金秀| 临洮县| 和静县| 民乐县| 思南县| 始兴县| 山阴县| 冕宁县| 舟山市| 邛崃市| 抚顺县| 永顺县| 时尚| 沭阳县| 新宾| 绵阳市| 华坪县| 深水埗区| 浦城县| 封丘县| 红原县| 雷山县| 嘉峪关市| 东海县| 阿鲁科尔沁旗| 宜州市| 宣汉县| 达拉特旗| 淮安市|