首页 技术 正文
技术 2022年11月11日
0 收藏 457 点赞 2,932 浏览 2031 个字

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

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

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

 public void AddChooseColumn(DataTable dt, bool isSelected)
{
if (dt == null || dt.Rows.Count == ) { 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 <= ) || (!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");

到此功能已经实现了。

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

相关推荐
python开发_常用的python模块及安装方法
adodb:我们领导推荐的数据库连接组件bsddb3:BerkeleyDB的连接组件Cheetah-1.0:我比较喜欢这个版本的cheeta…
日期:2022-11-24 点赞:878 阅读:9,497
Educational Codeforces Round 11 C. Hard Process 二分
C. Hard Process题目连接:http://www.codeforces.com/contest/660/problem/CDes…
日期:2022-11-24 点赞:807 阅读:5,910
下载Ubuntn 17.04 内核源代码
zengkefu@server1:/usr/src$ uname -aLinux server1 4.10.0-19-generic #21…
日期:2022-11-24 点赞:569 阅读:6,744
可用Active Desktop Calendar V7.86 注册码序列号
可用Active Desktop Calendar V7.86 注册码序列号Name: www.greendown.cn Code: &nb…
日期:2022-11-24 点赞:733 阅读:6,498
Android调用系统相机、自定义相机、处理大图片
Android调用系统相机和自定义相机实例本博文主要是介绍了android上使用相机进行拍照并显示的两种方式,并且由于涉及到要把拍到的照片显…
日期:2022-11-24 点赞:512 阅读:8,135
Struts的使用
一、Struts2的获取  Struts的官方网站为:http://struts.apache.org/  下载完Struts2的jar包,…
日期:2022-11-24 点赞:671 阅读:5,298