铁雪资源网 Design By www.gsvan.com

本例子使用自定义控件方法实现,数据库使用的是SQL Server,实现过程如下:

    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
    }

    5、执行程序:

DataGridView使用自定义控件实现简单分页功能(推荐)

    总结

以上所述是小编给大家介绍的DataGridView使用自定义控件实现简单分页功能,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!

标签:
datagridview实现分页,datagridview自定义控件

铁雪资源网 Design By www.gsvan.com
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
铁雪资源网 Design By www.gsvan.com

评论“DataGridView使用自定义控件实现简单分页功能(推荐)”

暂无DataGridView使用自定义控件实现简单分页功能(推荐)的评论...

《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线

暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。

艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。

《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。