1、控件及列表展示

1)、控件

2)、构建表格,用于列表展示

3)、gridControl绑定数据

4)、调用绑定:BindDataSource(InitDt());

5)、展示列表

2、表格的列配置

1)、点击 Run Resigner弹出设计界面

2)、配置后的效果

3、列数据的格式设置

1)、数据

2)、时间

3)、自定义

效果

注:数据公式查找:

4、gridControl属性

Dock:none  和   Anchor:Top, Bottom, Left, Right      设置随窗体宽高变化而变化

gridView1.IndicatorWidth = 40; //自增列宽度
gridView1.OptionsView.ColumnAutoWidth = false; //自动调整列宽,使所有列的宽度和视图的宽度匹配
gridView1.OptionsCustomization.AllowSort = false;//禁止用户对数据进行排序操作
gridView1.OptionsCustomization.AllowColumnResizing = false; //禁止各列头改变列宽
gridView1.OptionsCustomization.AllowColumnMoving = false;//各列头禁止移动
gridView1.VertScrollVisibility = ScrollVisibility.Auto; //显示垂直滚动条
gridView1.HorzScrollVisibility = ScrollVisibility.Auto; //显示水平滚动条
gridView1.OptionsMenu.EnableColumnMenu = false; //禁止列头上的菜单
gridView1.OptionsMenu.EnableFooterMenu = false; //禁止页脚上的菜单
gridView1.OptionsMenu.EnableGroupPanelMenu = false; //禁止分组面板上的菜单
gridView1.OptionsNavigation.UseTabKey = false; //不使用TAB/SHIFT+TAB移动焦点
gridView1.OptionsBehavior.Editable = false;//不允许编辑
gridView1.OptionsBehavior.ReadOnly = true;//只读

5、属性设置

1)、

//如何解决单击记录整行选中的问题
View->OptionsBehavior->EditorShowMode 设置为:Click

2)、

//焦点单元格的列
gridview1.FocusedColumn //焦点单元格所在行的行号
gridview1.FocusedRowHandle //焦点单元格的值
gridview1.FocusedValue

3)、

//如何解决 GridControl 记录能获取而没有显示出来的问题
gridView.populateColumns();

4)、

//如何让行只能选择而不能编辑(或编辑某一单元格)
View->OptionsBehavior->EditorShowMode 设置为:Click
View->OptionsBehavior->Editable 设置为:false

5)、

//如何禁用 GridControl 中单击列弹出右键菜单
Run Design->OptionsMenu->EnableColumnMenu 设置为:false

6)、

//如何隐藏 GridControl 的 GroupPanel 表头
Run Design->OptionsView->ShowGroupPanel 设置为:false

7)、

//如何禁用 GridControl 中列头的过滤器:
Run Design->OptionsCustomization->AllowFilter 设置为:false

8)、

//多选
GridControl->GridView->属性->OptinosSelecttion->MultiSelect

9)、

//在gridcontrol中添加checkbox复选框
gridview->run designer->columns->选择要变成复选框的那一列->column edit->new(在这里可以选择很多类型)

10)、

//显示自动筛选行(效果跟Excel的自动筛选差不多),列表的表格内部的自动筛选
gv2.OptionsView.ShowAutoFilterRow = true;

11)、

//设置成一次选择一行,并且不能被编辑
this.gridView1.FocusRectStyle = DevExpress.XtraGrid.Views.Grid.DrawFocusRectStyle.RowFocus;
this.gridView1.OptionsBehavior.Editable = false;
this.gridView1.OptionsSelection.EnableAppearanceFocusedCell = false;

12)、

//设置行号宽
gridView1.IndicatorWidth = 30;

13)、

//设置列表数据居中
gridview->run designer->columns->选择列->AppearanceCell和AppearanceHeader ->TextOptions->HAlignment属性设置为Center

6、分组排列汇总

分组

1)按时间分第一组

2)按性别分第二组

效果

3)高级设置

将所有组展开:gridView1.ExpandAllGroups();

4)、结果:

5)、自定义组名   gridView1_CustomDrawGroupRow

结果:

注意:每一行都有一个 RowHandle属性,普通行的RowHandle从0开始

排列设置

汇总

注:汇总结果显示在Footer面板中,gridControl的Footer面包默认不显示

结果:

7、行备注和行号

备注

1)、备注显示设置

2)、设置备注字段

结果

3)使用电脑键盘控制显示与隐藏

a、设置Form窗体的KeyPreview属性为true

b、注册窗体的KeyUp事件

private void Form2_KeyUp_1(object sender, KeyEventArgs e)
{
if (e.KeyCode == Keys.F3)
{
gridView1.OptionsView.ShowPreview = !gridView1.OptionsView.ShowPreview;
}
}

行号

gridView1_CustomDrawRowIndicator事件

行号宽:gridView1.IndicatorWidth = 30;

private void gridView1_CustomDrawRowIndicator(object sender, DevExpress.XtraGrid.Views.Grid.RowIndicatorCustomDrawEventArgs e)
{
    if (e.Info.IsRowIndicator)
    {
       e.Info.DisplayText = e.RowHandle.ToString();
    }
}

结果

8、设置字体颜色

private void gridView1_RowCellStyle(object sender, DevExpress.XtraGrid.Views.Grid.RowCellStyleEventArgs e)
{
if (e.Column.FieldName == "TestResult")//设字体颜色
{
Result tr = Result.Running;switch (tr)
{
case Result.Success:
e.Appearance.ForeColor = Color.Black;
break; default:
e.Appearance.ForeColor = Color.Black;
break;
}
}
}

9、右键菜单

1.在VS工具箱中的“菜单和工具栏”找到ContextMenuStrip控件,双击添加。
2.点击ContextMenuStrip右上方的小三角形,打开编辑项,可以添加菜单项。至于菜单点击事件,这里就不多说了。
3.选择gridControl(注意这里不是gridView的属性),在属性中可以找到ContextMenuStrip属性,设置成刚添加的ContextMenuStrip。
4.是否可用设置

问题:在单选时,“打开”(itemOpen)、“删除”(itemDelete)菜单项都可用,多选时“打开”不可用,“删除”可用,没有选择时“打开”、“删除”都不可用。

这里需要用到gridView的PopupMenuShowing这个事件。也就是在菜单出现之前用户点击右键之后,来判断一下选择了几行,从而决定菜单项是否可用。

private void gridView_PopupMenuShowing(object sender, DevExpress.XtraGrid.Views.Grid.PopupMenuShowingEventArgs e)
{
   //获取选择的行数
   int select = gridView.SelectedRowsCount;
   itemOpen.Enabled = false;
   itemDelete.Enabled = false;
   if(select == 1)
   {
     itemOpen.Enabled = true;
     itemDelete.Enabled = true;
   }
   else if(select > 1)
   {
     itemDelete.Enabled =true;
   }
}

样式设置

全部设置

新增一条记录

(1)、

private void btn_add_Click(object sender, EventArgs e)
{
gridView1.AddNewRow();
}

(2)、实现 gridView_InitNewRow 事件(对于新加行的特别的设置)

private void gridView1_InitNewRow(object sender, DevExpress.XtraGrid.Views.Grid.InitNewRowEventArgs e)

{
ColumnView View = sender as ColumnView;
View.SetRowCellValue(e.RowHandle, View.Columns[0], gridView1.GetRowCellValue(gridView1.GetRowHandle(gridView1.RowCount - 2), gridView1.Columns[0])); //复制最后一行的数据到新行
View.SetRowCellValue(e.RowHandle, View.Columns[1], gridView1.GetRowCellValue(gridView1.GetRowHandle(gridView1.RowCount - 2), gridView1.Columns[1])); //复制最后一行的数据到新行
}

自定义列显示事件

Devexpress控件使用一:GridControl的更多相关文章

  1. DevExpress 控件使用之GridControl基本属性设置

    DEV控件:gridControl常用属性设置     1.隐藏最上面的GroupPanel(实现方法两种)     ①代码实现:gridView1.OptionsView.ShowGroupPane ...

  2. c# devExpress控件 comboBoxEdit,gridControl1,labelcontrol

    一.comboBoxEdit:下拉框 属性 添加项:Properties->items 二.gridControl gridControl与Gridview的区别:前者是容器,后者为视图 2)g ...

  3. DevExpress控件的GridControl控件小结

    DevExpress控件的GridControl控件小结 (由于开始使用DevExpress控件了,所以要点滴的记录一下) 1.DevExpress控件组中的GridControl控件不能使横向滚动条 ...

  4. DevExpress控件-- Gridcontrol合并表头

    写在前面的话: 在园子里逛了有一段时间了,一直想写点东西,但苦于自己的水平有限,生怕写出来的东西浪费了读者的时间.楼主有幸参加了公司DevExpress控件的培训,独乐乐不如众乐乐,特附上Demo以飨 ...

  5. DevExpress 控件 GridControl常见用法

    刚接触DevExpress第三方控件,把GridControl的常见用法整理一下,以供参考: 说明: gcTest   GridControl gvText    GridView //隐藏最上面的G ...

  6. DevExpress控件-GridControl根据条件改变单元格/行颜色--转载

    DevExpress控件-数据控件GridControl,有时我们需要根据特定条件改变符合条件的行或者单元格颜色达到突出显示目的,现在动起鼠标跟我一起操作吧,对的,要达到这个目的您甚至都不用动键盘. ...

  7. DevExpress控件的GridControl实现行多选

    最近用到DevExpress控件的GridControl控件,需要用到行多选的操作,在网上找的资料,自己总结一下. 先展示一下效果:

  8. DevExpress控件GridControl中的布局详解 【转】

    DevExpress控件GridControl中的布局详解 [转] 2012-10-24 13:27:28|  分类: devexpress |  标签:devexpress  |举报|字号 订阅   ...

  9. DevExpress控件-GridControl根据条件改变单元格(Dev GridControl 单元格着色)

    DevExpress控件-GridControl根据条件改变单元格颜色,如下图: 解决办法:可以参考:http://www.cnblogs.com/zeroone/p/4311191.html 第一步 ...

  10. DevExpress控件-GridControl根据条件改变单元格/行颜色(Dev GridControl 单元格着色) z

    DevExpress控件-数据控件GridControl,有时我们需要根据特定条件改变符合条件的行或者单元格颜色达到突出显示目的,现在动起鼠标跟我一起操作吧,对的,要达到这个目的您甚至都不用动键盘. ...

随机推荐

  1. BZOJ 3105 线性基 高斯消元

    思路: 按照从大到小排个序 维护两个数组 一个是消元后的 另一个是 按照消元的位置排的 不断 维护从大到小 (呃具体见代码) //By SiriusRen #include <cstdio> ...

  2. P1343 地震逃生

    题目描述 汶川地震发生时,四川**中学正在上课,一看地震发生,老师们立刻带领x名学生逃跑,整个学校可以抽象地看成一个有向图,图中有n个点,m条边.1号点为教室,n号点为安全地带,每条边都只能容纳一定量 ...

  3. 个人对于React的Diff算法的一点疑问(待更新)

    本人对于Diff算法也并未做深入研究,只是大概的看过一些博文了解了些原理,但依然有了如下疑问 : 对于vdom所表示的对象中,若在该oldObj和newObj之间,发现一个元素节点所表示的子对象不见了 ...

  4. Python学习——爬虫篇

    requests 使用requests进行爬取                 下面是我编写的第一个爬虫的脚本                   import requests # 导入reques ...

  5. 第一章 关于python

    Python简介 Python是什么?   python的创始人为吉多·范罗苏姆(Guido van Rossum).  “Python is a great object-oriented, int ...

  6. CF960F Pathwalks_权值线段树_LIS

    很不错的一道思维题. Code: #include<cstdio> #include<algorithm> #include<iostream> using nam ...

  7. Pyhton学习——Day26

    #多态:多态指的是一类事物有多种形态# import abc# class Animal(metaclass = abc.ABCMeta):# 同一类事物:动物# @abc.abstractclass ...

  8. js正则表达式注册页面表单验证

    可以这样校验 <html> <head> <meta http-equiv="Content-Type" content="text/htm ...

  9. 新手学python-Day4-作业

    购物车程序 要求: 1.启动程序后,让用户输入工资,然后打印商品列表 2.允许用户根据商品编号购买商品 3.用户选择商品后,检查余额是否足够,够了就扣款,不够就提醒 4.可随时退出,退出时,打印已购买 ...

  10. javaScript - 面向对象 - ES5 和 ES6

    javaScript - 面向对象 - ES5 和 ES6 ES5之前用 构造函数 构造函数的特点 就是一个普通函数, 他的函数名要大写.: 带方法的写法: 原型的方式: prototype 为内置的 ...