zoukankan      html  css  js  c++  java
  • DevExpress gridControl的使用技巧总结

    一、如何解决单击记录整行选中的问题

    View->OptionsBehavior->EditorShowMode 设置为:Click

    二、如何新增一条记录

    (1)、gridView.AddNewRow()

    (2)、实现gridView_InitNewRow事件

    三、如何解决GridControl记录能获取而没有显示出来的问题

    gridView.populateColumns();

    四、如何让行只能选择而不能编辑(或编辑某一单元格)

    (1)、View->OptionsBehavior->EditorShowMode 设置为:Click

    (2)、View->OptionsBehavior->Editable 设置为:false

    五、如何禁用GridControl中单击列弹出右键菜单

    设置Run Design->OptionsMenu->EnableColumnMenu 设置为:false

    六、如何隐藏GridControl的GroupPanel表头

    设置Run Design->OptionsView->ShowGroupPanel 设置为:false

    七、如何禁用GridControl中列头的过滤器

    设置 Run Design->OptionsCustomization->AllowFilter 设置为:false

    八、如何在查询得到0条记录时显示自定义的字符提示/显示

    方法如下:

    //When no Records Are Being Displayedprivate void gridView1_CustomDrawEmptyForeground(object sender, CustomDrawEventArgs e){     //方法一(此方法为GridView设置了数据源绑定时,可用)     ColumnView columnView = sender as ColumnView;     BindingSource bindingSource = this.gridView1.DataSource as BindingSource;     if(bindingSource.Count == 0)     {          string str = "没有查询到你所想要的数据!";          Font f = new Font("宋体", 10, FontStyle.Bold);          Rectangle r = new Rectangle(e.Bounds.Top + 5, e.Bounds.Left + 5, e.Bounds.Right - 5, e.Bounds.Height - 5);          e.Graphics.DrawString(str, f, Brushes.Black, r);     }     //方法二(此方法为GridView没有设置数据源绑定时,使用,一般使用此种方法)      if (this._flag)     {          if (this.gridView1.RowCount == 0)          {               string str = "没有查询到你所想要的数据!";               Font f = new Font("宋体", 10, FontStyle.Bold);               Rectangle r = new Rectangle(e.Bounds.Left + 5, e.Bounds.Top + 5, e.Bounds.Width - 5, e.Bounds.Height - 5);               e.Graphics.DrawString(str, f, Brushes.Black, r);          }     }}

    九、如何显示水平滚动条?

    设置this.gridView.OptionsView.ColumnAutoWidth = false;

    十、如何定位到第一条数据/记录?

    设置 this.gridView.MoveFirst()

    十一、如何定位到下一条数据/记录?

    设置 this.gridView.MoveNext()

    十二、如何定位到最后一条数据/记录?

    设置 this.gridView.MoveLast()

    十三、设置成一次选择一行,并且不能被编辑

    this.gridView1.FocusRectStyle = DevExpress.XtraGrid.Views.Grid.DrawFocusRectStyle.RowFocus;this.gridView1.OptionsBehavior.Editable = false;this.gridView1.OptionsSelection.EnableAppearanceFocusedCell = false;

    十四、如何显示行号?

    this.gridView1.IndicatorWidth = 40;//显示行的序号private void gridView1_CustomDrawRowIndicator(object sender, RowIndicatorCustomDrawEventArgs e){     if (e.Info.IsRowIndicator && e.RowHandle>=0)     {          e.Info.DisplayText = (e.RowHandle + 1).ToString();     }}

    十五、如何让各列头禁止移动?

    设置gridView1.OptionsCustomization.AllowColumnMoving = false;

    十六、如何让各列头禁止排序?

    设置gridView1.OptionsCustomization.AllowSort = false;

    十七、如何禁止各列头改变列宽?

    设置gridView1.OptionsCustomization.AllowColumnResizing = false;

    原作者:huhm


    大多是网上零散找到的,小部分是自己使用的时候自己遇到的。

     

    XtraGrid的关键类就是:GridControl和GridView。GridControl本身不显示数据,数据都是显示在GridView/CardView/XXXXView中。GridControl是各种View的容器。所以要控制显示,要从GridView这些类入手。

     

    1.DevExpress控件组中的GridControl控件不能使横向滚动条有效。现象:控件中的好多列都挤在一起,列宽都变的很小,根本无法正常浏览控件单元格中的内容。

    解决:

    gridView1.OptionsView.ColumnAutoWidth属性是true,即各列的宽度自动调整,你把它设成false,就会出现了。


    2.使单元格不可编辑。

    gridcontrol -->gridview -->OptionsBehavior -->Editable=false

     

    3.去除"Drag a Column Header Here To Group by that Column"

    属性Gridview->Option View->Show Group Panel=false,就好了

     

    4.数据绑定

    (1) 在GridControl控件面板中点击clip_image002

    (2) 在出现的窗体中,点击左边的clip_image004进行列名的编辑。点击上方的clip_image006可添加一列,clip_image008插入一列,clip_image010移除一列。点击clip_image006[1]后在右边的属性面板中找到Caption设置显示的列标题和FieldName设置该列绑定数据的字段名,Visible设置列是否隐藏。

     

    绑定代码:

    gridControl2.DataSource = od.data_select("select * from tablename").Tables[0];//od是数据库操作类,data_select返回DataSet类型,绑定DataTable类型

     

    5.选择某行数据触发时间

    gridView2.RowClick += new DevExpress.XtraGrid.Views.Grid.RowClickEventHandler(gridView2_RowClick);

    这样设置以后必须点击最左边的行编号才可以触发事件,需要设置gridcontrol -->gridview -->OptionsBehavior -->Editable=false即可点击任意单元格触发事件。

     

    6.选择某行后获取当前表格数据

    this.textBox1.Text = gridView2.GetDataRow(e.RowHandle)["列名"].ToString();

     

    7.设置奇、偶行交替颜色

    (1) OptionsView.EnableAppearanceEvenRow = true;OptionsView.EnableAppearanceOddRow = true;

    (2) 设置Appearance.EvenRow.BackColor和Appearance.OddRow.BackColor

     

    8.在每行第一列显示行号

    (1) this.gridView2.IndicatorWidth = 30;//设置显示行号的列宽

    (2) 设置动作gridView2.CustomDrawRowIndicator += new DevExpress.XtraGrid.Views.Grid.RowIndicatorCustomDrawEventHandler(gridView2_CustomDrawRowIndicator);

    1
    2
    3
    4
    5
    6
    7
    8
    //添加行号
            void gridView2_CustomDrawRowIndicator(object sender, DevExpress.XtraGrid.Views.Grid.RowIndicatorCustomDrawEventArgs e)
            {
                if(e.Info.IsRowIndicator && e.RowHandle >= 0)
                {
                    e.Info.DisplayText = (e.RowHandle + 1).ToString();
                }
            }

     

    9.根据绑定的数据源自动产生列

    gridView2.PopulateColumns();


    作者:liulu 
    出处:http://www.cnblogs.com/liulunet/ 
    谢谢支持


  • 相关阅读:
    MySQL批量更新字段url链接中的域名
    巧用Win+R
    斯坦福高效睡眠法
    chkconfig: command not found
    Nginx(./configure --help)
    Ubuntu16.04配置Tomcat的80端口访问
    Binary Tree Level Order Traversal
    java——Arrays.asList()方法
    python 发送邮件
    常用邮件协议
  • 原文地址:https://www.cnblogs.com/dengshiwei/p/4258760.html
Copyright © 2011-2022 走看看