zoukankan      html  css  js  c++  java
  • Winform分页控件支持表头全选操作实现之最优方法

    在我之前的文章《Winform分页控件支持表头全选操作实现》中,有介绍过一种方法来实现DataGridView的表头全选操作,不过这种方式,是通过绑定字段的方式实现,每次需要创建一个字段来专门做这个列头绑定,显得有点多余。那有没有更好的方式呢,当然有,我这里介绍一种更好表头全选实现的方式,然后说明我的分页控件封装后是如何简单实现这种效果的。

    1)传统的DataGridView全选实现效果。

    抛开我的分页控件来讲,实现传统的DataGridView的表头全选的方式,只需要引入一个类DatagridViewCheckBoxHeaderCell,它继承自DataGridViewColumnHeaderCell,我们来看具体的使用代码:

    public FrmNormalGridViewSelect2()
            {
                InitializeComponent();
    
                if (!this.DesignMode)
                {
                    DataGridViewCheckBoxColumn colCB = new DataGridViewCheckBoxColumn();
                    DatagridViewCheckBoxHeaderCell cbHeader = new DatagridViewCheckBoxHeaderCell();
                    colCB.HeaderCell = cbHeader;
                    this.dgvSelectAll.Columns.Add(colCB);
    
                    cbHeader.OnCheckBoxClicked += new CheckBoxClickedHandler(cbHeader_OnCheckBoxClicked);
                }
            }
    
            void cbHeader_OnCheckBoxClicked(bool state)
            {
                foreach (DataGridViewRow Row in dgvSelectAll.Rows)
                {
                    Row.Cells[0].Value = state;
                    Row.Selected = state;
                }
                this.dgvSelectAll.RefreshEdit();
            }

    这样额外的代码操作即可实现表头全选的操作了,实现效果如下所示

    2)基于DevExpress的GridControl控件的全选实现。

    做戏做全套,我们在开发中,也经常使用到基于DevExpress的系统界面开发,那么,不用创建字段的方式,在GridControl中有无好的实现方法呢。当然有,下面我来介绍一下。

    首先引入一个GridCheckMarksSelection类,这个类就是用来实现这种全选效果的,我们看看其使用的代码。

            public FrmDevGridViwSelect2()
            {
                InitializeComponent();
    
                this.gridView1.OptionsBehavior.Editable = true;
                this.gridView1.OptionsBehavior.ReadOnly = false;
                this.gridControl1.DataSourceChanged += new EventHandler(gridControl1_DataSourceChanged);
            }
    
            void gridControl1_DataSourceChanged(object sender, EventArgs e)
            {
                GridCheckMarksSelection selection = new GridCheckMarksSelection(gridView1);
                selection.CheckMarkColumn.VisibleIndex = 0;
                selection.CheckMarkColumn.Width = 60;
            }

    是不是很简单呢,它最终实现的效果会如下所示。

     

    3)基于我的分页控件的全选操作

    有这么好的实现效果,我当然会把它集成到我的分页控件里面了,当然,为了追求简单就是美的方式,我会尽量简化客户的使用代码。我们只需要设置一个属性即可实现表头全选的操作了(DevExpress版本和传统版本代码一样)。

    this.winGridViewPager1.ShowCheckBox = true;

    我们来看看基于我的分页控件实现的表头全选功能,界面效果如何。

    1)传统界面的效果

     

    2)DotNetBar界面效果

     

    3)DevExpress界面效果 

     

    这样的简单调用就能实现表头全选的操作,不需要另外其他额外的操作,是不是很好,简洁呢?这其实就是我追求的表头全选的最优方法了。

    最后,可能读者还有一个疑问,就是我全选或者部分选择,我要知道我选择的是那些行,该怎么操作呢?放心,我这个分页控件也已经为你考虑了,呵呵。

    通过调用下面的代码即实现。

            private void btnGetCheckedRows_Click(object sender, EventArgs e)
            {
                List<int> list = this.winGridViewPager1.GetCheckedRows();
                StringBuilder sb = new StringBuilder();
                int i = 1;
                foreach (int rowindex in list)
                {
                    sb.Append(rowindex.ToString() + ",");
                    if (i++ % 10 == 0)
                    {
                        sb.Append("\r\n");
                    }
                }
                MessageUtil.ShowTips(sb.ToString());
            }

    演示例子下载:

    分页控件传统界面例子  分页控件DevExpress样式例子

    主要研究技术:代码生成工具、会员管理系统、客户关系管理软件、病人资料管理软件、Visio二次开发、酒店管理系统、仓库管理系统等共享软件开发
    专注于Winform开发框架/混合式开发框架Web开发框架Bootstrap开发框架微信门户开发框架的研究及应用
      转载请注明出处:
    撰写人:伍华聪  http://www.iqidi.com 
        
  • 相关阅读:
    Linux编程之自定义消息队列
    MVC5学习系列--Razor视图(一)
    JS将秒转换为 天-时-分-秒
    自己封装了一个EF的上下文类.,分享一下,顺便求大神指点
    VS2015企业版,社区版,专业版详细对比
    [干货来袭]C#6.0新特性
    WebApp上滑加载数据...
    用SignalR 2.0开发客服系统[系列5:使用SignalR的中文简体语言包和其他技术点]
    用SignalR 2.0开发客服系统[系列4:负载均衡的情况下使用SignalR]
    用SignalR 2.0开发客服系统[系列3:实现点对点通讯]
  • 原文地址:https://www.cnblogs.com/wuhuacong/p/2544628.html
Copyright © 2011-2022 走看看