dev 中的GridControl中的行实现选择的功能实现

  1、项目有实现不GridControl中的数据导出Excel的功能,导出的时候是把所有的数据全部导出,现在要实现可供选择的灵活的导出功能。除了全选可全不选,还可以对每一行实现选择的功能。实现起来比较简单,界面也很简单,先贴一下实现的界面。

  2、实现思路:先要在传给GridControl的DataTable中增加新的字段,字段名称可以自己选择,显示出方框的形状以供选择。默认全部选择,所以调用函数时,传入的isSelected为false。实现代码:

 public void AddChooseColumn(DataTable dt, bool isSelected)
        {
            if (dt == null || dt.Rows.Count == 0) { return; }
            if (dt.Columns.Contains("CHOOSE")) { return; }
            dt.Columns.Add("CHOOSE", typeof(Boolean));
            dt.Columns["CHOOSE"].DefaultValue = false;
            foreach (DataRow row in dt.Rows)
                row["CHOOSE"] = isSelected;
            dt.AcceptChanges();
        }

  3、实现全选和全部不选的功能,由第二步知道当新增字段“CHOOSE”为false时是,全不选,那么当用户单击CheckEdit时(窗体上的全选选择框name为chkSelectAll)时,把字段“CHOOSE”设置成true即可实现全选功能。全选选择框的实现代码如下:

 Action<bool> allOrNotAll = flag =>
            {
                foreach (DataRow row in dt.Rows)
                {
                    foreach (DataColumn column in dt.Columns)
                    {
                        string name = column.ColumnName;
                        if (name.Equals(DataTableField.CHOOSE.ToString()))
                        {
                            row[name] = flag;
                        }
                    }
                }
            };
  //全选
  this.chkSelectAll.CheckStateChanged += (x, y) => allOrNotAll(this.chkSelectAll.Checked);

原本的代码是这样的:this.chkSelectAll.CheckStateChanged += delegate{ allOrNotAll(this.chkSelectAll.Checked);};因为有大括号,所以delegate之后的大括号在代码中单独占了一行,而大括号中的代码却只有一行,所以为了看起来更加清晰,改为了: this.chkSelectAll.CheckStateChanged += (x, y) => allOrNotAll(this.chkSelectAll.Checked); 参数想x,y是,object,EventArgs,在代码中没有用到,所以简单命名成想x,y.

  4、现在实现单选一行就可以了,思路是:当用户单击时,根据单击的坐标,对应的DataRow,如果对应的ColumnName=“CHOOSE”,那么就可以断定是要选择这一行。所以把数据中的row["CHOOSE"]设置为true,显示选中状态即可。代码如下所示。

 private static void SelectTicket(MouseEventArgs e, ColumnView gridView, string columnFieldName)
        {
            GridHitInfo hint = (GridHitInfo)gridView.CalcHitInfo(e.X, e.Y);
            if ((gridView.RowCount <= 0) || (!hint.InRowCell) || (hint.Column != gridView.Columns[columnFieldName]))
                return;
            DataRow hintRow = gridView.GetDataRow(hint.RowHandle);
            if (hintRow == null)
                return;
            if (hintRow[columnFieldName] == null)
                return;
            hintRow["CHOOSE"] = !(bool)hintRow["CHOOSE"];
        }

调用此函数的代码是:

            this.gridOperatorTask.Click += (obj, e) => SelectTicket((MouseEventArgs)e, this.advBandedGridView1, "CHOOSE");

到此功能已经实现了。

  感想:最近要过年了,一直都心思没写博客,看到别人写的很好的博客,从其中学到了好多知识,心里非常感激。今天把自己解决的问题写出来,万一有人遇到了可以参考一下。知识在于分享,以后要像其他优秀的人那样,不仅在停学习新的知识,而且把心得、总结写成博客分享出来,有很多的文章都使我受益匪浅。

时间: 2024-08-29 23:10:48

dev 中的GridControl中的行实现选择的功能实现的相关文章

WPF datagrid/gridcontrol 中选中多行,复制粘贴到excel或其他文本编辑器中

wpf中 data grid 开启自带的选中,然后复制,可以到excel中直接粘贴,在某些业务场景中很实用,方便.开启也很简单: SelectionMode="Row" 加上这个,按ctrl或shift然后鼠标单击行选中 <dxg:GridControl x:Name="user_GridControl" SelectionMode="Row" > </dxg:GridControl> 原文地址:https://www.c

老男孩教育每日一题:2017年3月9日-请解释下面Shell脚本中if开头的整行代码的意思及应用场景吗?

请解释下面Shell脚本中 if开头的整行代码的意思,你见过它的应用场景么? if(kill -0 $pid 2>/dev/du11) then     echo"oldboy" else    echo"oldgirl" fi 面试题:请解释if (kill -0 $pid 2>/dev/null)代码的意思? if(kill -0 $pid 2>/dev/null)     then        echo "oldboy"

WPF界面开发:DevExpress WPF在GridControl中固定行时处理时刻

DevExpress广泛应用于ECM企业内容管理. 成本管控.进程监督.生产调度,在企业/政务信息化管理中占据一席重要之地.通过DevExpress WPF Controls,您能创建有着强大互动功能的XAML基础应用程序,这些应用程序专注于当代客户的需求和构建未来新一代支持触摸的解决方案. 无论是Office办公软件的衍伸产品,还是以数据为中心的商业智能产品,都能通过该控件来实现. 本文 将为大家介绍如何在GridControl中固定行时处理时刻.在接下来的系列文章中,小编将为大家介绍一些De

[WinForm][DevExpress]自定义GridControl中按钮文字内容

最近项目开发中,使用到了GridControl的FindPanel,这样可以很好的对数据进行筛选,可是所展现的按钮文字是英文,如图: 那怎么定义两个按钮问题,以符合项目需求了?经过一番搜索发现利用GridLocalizer可以很好实现: 核心代码: public class BuilderGridLocalizer : GridLocalizer { Dictionary<GridStringId, string> CusLocalizedKeyValue = null; /// <su

获取所有分组中某列最大的行

怎么获取所有分组中某列最大的行?下面用一个例子来说明下: 一共公司有若干员工,每个员工有各自的id, group_id(部门), salary(工资).现在的问题转变为 求公司各部门最高工资的员工 首先明确一个问题,一个部门的若干个员工可能同时拥有最高的工资,需要都列举出来. 看一下员工的数据库表结构(只包含有用的列): Field Type Null Key Default Extra id int(11) NO PRI NULL   group_id int(11) YES   NULL  

Linux 中常用的文本(行)处理命令(转)

Linux 中常用的文本(行)处理命令 0.正则表达式(regular expression) 元字符(如下图)是正则表达式中含有的字符,在正则表达式中可以在字符串中使用元字符以匹配字符串的各种可能的情况. 注意: (1) 在"[ ]"中还可以使用"-"来表示某一范围.例如"[a-z0-9]"匹配任意的小写字母或者数字,"[^A-Z]"表示非大写字母,"[0-9]{8}"表示任意一个8位数字. (2) 元字

获取GridView中RowCommand的当前索引行

原文:http://blog.csdn.net/sabty/article/details/4816160 获取GridView中RowCommand的当前索引行 前台添加一模版列,里面添加一个LinkButton 前台 (如果在后台代码中用e.CommandArgument取值的话前台代码就必须在按钮中设置CommandArgument的值,值为绑定的数据库字段 <asp:TemplateField HeaderText="操作"> <ItemTemplate>

oracle中的rowid和数据行的结构

在oracle数据库系统中每一行都有一个rowid,oracle数据库系统就是利用rowid来定位数据行的.rowid也是oracle中内置的一个标量数据类型 rowid有一下特点; 是数据库中每一行的唯一标识 并不是显示的存储某一列的值 可以用来定位行,虽然没有直接给出行的物理地址 提供了访问一张表中数据行的最快机制 1)rowid有两种类型:限制rowid和扩展rowid 一.扩展rowid 扩展rowid是oracle8i之后的版本中引入的,其结构如下: 数据对象号+相对文件号+块号+行号

EXTJS中的grid显示实际行号

添加一个新的功能 [javascript] view plaincopy Ext.grid.PageRowNumberer = Ext.extend(Ext.grid.RowNumberer, { width : 40, renderer:function(value, cellmeta, record, rowIndex, columnIndex, store){ if(store.lastOptions.params!=null){ var pageindex=store.lastOptio