C# .net+DevExpress自定义控件(UserControl)之分页控件

1、需求

在开发桌面系统时难免会碰到一些很大的表格,上千行甚至上万行,如果把这些表格全部用GridControl展示出来难免会觉得系统很臃肿,而且会影响系统的效率,所以对表格进行分页就比较重要了。其实在Dev中有自带的所谓“分页控件DataNavigation”,但是那个和我们一般使用的还是有很大区别,dev自带的分页控件准确来说是一个导航控件,显示的还是一张大表。

2、分页控件UI设计

分页控件界面设计
左边是上下页和首末页的label,点击控件触发响应事件,还可以在文本框中输入页码来指定页跳转,还可以设置每页显示的条数。

3、代码实现

3.1属性和私有变量的定义

我定义了绑定的GridControl控件(BindingGrid)、原始表(BindingDataTable)、显示表(ShowingDataTable)和其他用于显示表格信息的属性。这样做有一个问题,如果绑定的表格控件绑定的数据是列表那么就比较麻烦,优化的时候可以在这个点进行优化。

		#region 定义变量
        private int dataSourceRowsCount;
        #endregion

        #region 定义属性
        /// <summary>
        /// 绑定的表格控件
        /// </summary>
        public GridControl BindingGrid
        {
            get; set;
        }

        /// <summary>
        /// 和控件关联的表格
        /// </summary>
        public DataTable BindingDataTable
        {
            get; set;
        }

        /// <summary>
        /// 显示的表格
        /// </summary>
        public DataTable ShowingDataTable
        {
            get; set;
        }

        /// <summary>
        /// 总页数
        /// </summary>
        public int TotalPages
        {
            get; set;
        }

        /// <summary>
        /// 当前页
        /// </summary>
        public int CurrentPage
        {
            get; set;
        }

        /// <summary>
        /// 每页条数
        /// </summary>
        public int RowsCount
        {
            get; set;
        }
        #endregion

3.2控件初始化

我这里最开始没设计好,需要提供两个参数进行控件初始化,后期可以优化成只提供GridControl参数进行初始化。

		/// <summary>
        /// 初始化控件显示
        /// </summary>
        /// <param name="dataTable"></param>
        public void InitCtrl(DataTable dataTable, GridControl gridControl)
        {
            try
            {
                #region 初始化属性
                BindingGrid = gridControl;
                BindingDataTable = dataTable;
                RowsCount = Convert.ToInt32(cbxRowCount.Text);
                dataSourceRowsCount = BindingDataTable.Rows.Count;
                TotalPages = (int)Math.Ceiling((double)dataSourceRowsCount / RowsCount);
                CurrentPage = dataSourceRowsCount == 0 ? 0 : 1;
                ShowingDataTable = new DataTable();
                if (BindingDataTable.Rows.Count == 0)
                {
                    #region 初始化控件显示
                    tbxCurrentPage.Text = CurrentPage.ToString();
                    lbTotalPages.Text = TotalPages.ToString();
                    lbTotalRows.Text = "共 " + dataSourceRowsCount.ToString() + " 条记录";
                    #endregion
                    return;
                }
                if (BindingDataTable.Rows.Count > 0 && BindingDataTable.Rows.Count <= RowsCount)
                {
                    ShowingDataTable = BindingDataTable.Copy();
                }
                else
                {
                    DataColumnCollection dataColumns = BindingDataTable.Columns;
                    foreach (DataColumn dataColumn in dataColumns)
                    {
                        ShowingDataTable.Columns.Add(dataColumn.ColumnName, dataColumn.DataType);
                    }
                    DataRow dataRow = null;
                    for (int i = 0; i < 20; i++)
                    {
                        dataRow = ShowingDataTable.NewRow();
                        int s = ShowingDataTable.Rows.Count;
                        dataRow = BindingDataTable.Rows[i];
                        ShowingDataTable.ImportRow(dataRow);
                    }
                }
                #endregion

                #region 初始化控件显示
                tbxCurrentPage.Text = CurrentPage.ToString();
                lbTotalPages.Text = "共 " + TotalPages.ToString() + " 页";
                lbTotalRows.Text = "共 " + dataSourceRowsCount.ToString() + " 条记录";
                #endregion
            }
            catch (Exception ex)
            {
                XtraMessageBox.Show("初始化列表失败");
                //添加日志记录相关方法
            }
            finally
            {
                BindingGrid.DataSource = ShowingDataTable;
                BindingGrid.Refresh();
            }
        }

3.3 上下页和首末页点击事件

        //点击首页按钮
        private void lbFirstPage_Click(object sender, EventArgs e)
        {
            if (CurrentPage == 1)
                return;
            CurrentPage = 1;
            tbxCurrentPage.Text = CurrentPage.ToString();
            SetShowingDataTable();
        }

        //点击上一页按钮
        private void lbPrePage_Click(object sender, EventArgs e)
        {
            if (CurrentPage == 1)
                return;
            CurrentPage--;
            tbxCurrentPage.Text = CurrentPage.ToString();
            SetShowingDataTable();
        }

        //点击下一页按钮
        private void lbNextPage_Click(object sender, EventArgs e)
        {
            if (CurrentPage == TotalPages)
                return;
            CurrentPage++;
            tbxCurrentPage.Text = CurrentPage.ToString();
            SetShowingDataTable();
        }

        //末页按钮
        private void lbEnd_Click(object sender, EventArgs e)
        {
            if (CurrentPage == TotalPages)
                return;
            CurrentPage = TotalPages;
            tbxCurrentPage.Text = CurrentPage.ToString();
            SetShowingDataTable();
        }

上面的代码中,SetShowingDataTable()方法用来生成显示的表格:

        /// <summary>
        /// 根据当前页、显示行数确定显示的表格
        /// </summary>
        private void SetShowingDataTable()
        {
            try
            {
                if (BindingDataTable.Rows.Count <= RowsCount)
                {
                    ShowingDataTable = BindingDataTable.Copy();
                    return;
                }
                else
                {
                    int startRowIndex = (CurrentPage - 1) * RowsCount;
                    int endRoeIndex = startRowIndex + RowsCount;
                    if (endRoeIndex > BindingDataTable.Rows.Count)
                    {
                        endRoeIndex = BindingDataTable.Rows.Count;
                    }
                    ShowingDataTable.Rows.Clear();
                    DataRow dataRow = null;
                    for (int i = startRowIndex; i < endRoeIndex; i++)
                    {
                        dataRow = ShowingDataTable.NewRow();
                        dataRow = BindingDataTable.Rows[i];
                        ShowingDataTable.ImportRow(dataRow);
                    }
                }
            }
            catch (Exception ex)
            {
                XtraMessageBox.Show("列表显示失败");
                //添加日志记录相关方法
            }
            finally
            {
                BindingGrid.DataSource = ShowingDataTable;
                BindingGrid.Refresh();
            }
        }
        #endregion

3.4 更改条数和跳转指定页

        //选择每页显示条数
        private void cbxRowCount_SelectedIndexChanged(object sender, EventArgs e)
        {
            RowsCount = Convert.ToInt32(cbxRowCount.Text);
            CurrentPage = 1;
            TotalPages = (int)Math.Ceiling((double)BindingDataTable.Rows.Count / RowsCount);
            ShowingDataTable.Rows.Clear();
            SetShowingDataTable();

            tbxCurrentPage.Text = CurrentPage.ToString();
            lbTotalPages.Text = TotalPages.ToString();
        }

        //手动输入显示页面编号
        private void tbxCurrentPage_KeyDown(object sender, KeyEventArgs e)
        {
            if (e.KeyCode == Keys.Enter)
            {
                int page = Convert.ToInt32(tbxCurrentPage.Text);
                if (page < 1)
                {
                    CurrentPage = 1;
                    tbxCurrentPage.Text = "1";
                }
                else if (page > TotalPages)
                {
                    CurrentPage = TotalPages;
                    tbxCurrentPage.Text = CurrentPage.ToString();
                }
                else
                {
                    CurrentPage = page;
                    tbxCurrentPage.Text = CurrentPage.ToString();
                }
                SetShowingDataTable();
            }
        }

3.5 调用自定义分页控件

在控件初始化之后,直接调用InitCtrl()方法进行初始化:

//vs自动生成的代码
private UserControls.Data.CtrlGridNavigation ctrlGridNavigation1;
this.ctrlGridNavigation1 = new UserControls.Data.CtrlGridNavigation();
//

ctrlGridNavigation1.InitCtrl(bindingDataTable, bindingGridControl);

4、代码下载

github:github下载
CSDN:CSDN下载

  • 1
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Winform+DevExpress分页控件是一种用于Windows桌面应用程序开发的控件,它可以帮助开发者实现数据分页显示的功能。DevExpress是一个知名的UI控件库,它提供了丰富的控件和组件,可以大大提高开发效率和用户体验。分页控件可以帮助用户快速浏览大量数据,同时也可以提高应用程序的性能和响应速度。 ### 回答2: WinForm DevExpress分页控件是一个强大的工具,它使用户能够快速而可靠地管理大量数据。该控件可以在WinForm应用程序中轻松实现常见的数据分页方案,并且具有灵活的布局和样式选项。以下是一些关于这个控件的主要特点和功能: 1. 高度可定制:可以自定义控件的行数、页码样式、默认选中颜色等; 2. 支持大数据量:对于海量数据,控件可以极快地将其分页,显示出一页一页数据; 3. 轻松互动和导航:用户可以轻松进行分页,并且快速能够找到所需的数据; 4. 灵活的事件和属性:提供了一系列事件和属性,便于用户轻松地自定义控件的行为和外观; 5. 查找和过滤功能:控件允许用户按照特定标准进行筛选和查找数据; 6. 高度可定制的主题:用户可以自定义主题、颜色和字体等特性,使控件更符合实际的需求。 需要注意的是,WinForm DevExpress分页控件可能会对一些软件开发者提出一些挑战,因此在使用过程中一定要对其进行认真学习和测试。不过,如果合理使用,该控件可以大大提高数据管理的效率和质量,为软件开发者带来极大的价值。 ### 回答3: WinForm DevExpress是一种方法,用于创建用户友好的Windows桌面应用程序,包括数据绑定和视觉效果。在WinForm中可以使用许多控件来开发应用程序,例如文本框、按钮、标签、复选框等,这些控件可用于显示数据和收集用户输入。其中一个重要的控件就是分页控件分页控件在WinForm应用程序中非常常见,因为它允许用户浏览大量的数据,并按照需要进行分页DevExpress分页控件提供了丰富的功能,可以让用户以非常灵活的方式对分页进行定制。 在DevExpress分页控件中,我们可以设置每页显示的记录数,可以选择要显示的页码,还可以自定义分页按钮的外观和行为。此外,分页控件还可以根据需要自动调整页面大小,并支持跳转到指定页码。 与其他分页控件相比,DevExpress分页控件具有较高的灵活性和可定制性。通过使用分页控件,我们可以使应用程序更加用户友好,让用户以最高效和最直观的方式来浏览和处理数据。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值