• C#窗体控件DataGridView常用设置


    C#窗体控件DataGridView常用设置

    在默认情况下,datagridview的显示效果:

    1.禁用最后一行空白。

      默认情况下,最后一行空白表示自动新增行,对于需要在控件中进行编辑,可以保留

    dataGridView1.AllowUserToAddRows = false;

      上述禁用,仅是将用户界面交互的自动新增行禁了,但还是可以通过代码:dataGridView1.Rows.Add();来新增一行空白。

    2.禁用‘delete’键的删除功能。

      默认情况,鼠标选中一整行,按 删除键 可以删除当前一整行

    dataGridView1.AllowUserToDeleteRows = false;

      上述禁用,仅是将用户界面交互的自动新增行禁了,但还是可以通过代码:

        dataGridView1.Rows.Remove(DataGridViewRow dataGridViewRow);

        或者 dataGridView1.Rows.RemoveAt(int index);

    来删除指定行数据。

    3.启用鼠标拖拽列功能

      启用后,可以通过鼠标拖拽,对列的顺序进行重排序。但是拖拽不会影响各列通过代码访问时的列序号(保持原来的序号),只是展示效果变化。

    dataGridView1.AllowUserToOrderColumns = true;

     4.禁用鼠标拖动行高度、列宽度

      禁用后,不能通过鼠标交互改变列的宽度和行的高度。不影响通过代码设置

     dataGridView1.AllowUserToResizeColumns = false; // 禁拖动列宽度  dataGridView1.AllowUserToResizeRows = false;    // 禁拖动行高度

     

    5.禁用鼠标拖动行标题(最左侧空白列)宽度 

    dataGridView1.RowHeadersWidthSizeMode = DataGridViewRowHeadersWidthSizeMode.DisableResizing; // 枚举,可以枚举位自适应大小

     

    6.禁用单元格编辑功能

    dataGridView1.ReadOnly = true;

     7.点击选中整行、整列

    dataGridView1.SelectionMode = DataGridViewSelectionMode.FullRowSelect;// 单击选中整行,枚举

       SelectionMode 为枚举类型:

    CellSelect  可以选定一个或多个单元格
    FullRowSelect通过单击行的标头或是该行所包含的单元格选定整个行
    FullColumnSelect通过单击列的标头或该列所包含的单元格选定整个列
    RowHeaderSelect 通过单击行的标头单元格选定此行。 通过单击某个单元格可以单独选定此单元格。
    ColumnHeaderSelect可以通过单击列的标头单元格选定此列。 通过单击某个单元格可以单独选定此单元格。

     

     

     

     

     

    8.禁用多行/多列/多单元格选择

    dataGridView1.MultiSelect = false;

    9.设置表格网格线颜色等样式

    dataGridView1.AdvancedCellBorderStyle.Top = DataGridViewAdvancedCellBorderStyle.InsetDouble; // 设置边框样式(上边框),枚举:双线内陷边框 // ... dataGridView1.GridColor = Color.SeaGreen; //边框线 颜色

     10.自动行序号

       没有直接的设置属性,需要借助控件渲染事件:dataGridView1.CellPainting+=dataGridView1_CellPainting;

    复制代码
            //在单元格需要绘制时发生。         private void dataGridView1_CellPainting(object sender, DataGridViewCellPaintingEventArgs e)         {             if (e.ColumnIndex < 0 && e.RowIndex >= 0) // 绘制 自动序号             {                 e.Paint(e.ClipBounds, DataGridViewPaintParts.All);                 Rectangle vRect = e.CellBounds;                 vRect.Inflate(-2, 2);                 TextRenderer.DrawText(e.Graphics, (e.RowIndex + 1).ToString(), e.CellStyle.Font, vRect, e.CellStyle.ForeColor, TextFormatFlags.Right | TextFormatFlags.VerticalCenter);                 e.Handled = true;             }
    // ----- 其它样式设置 ------- if (e.RowIndex % 2 == 0) { // 行序号为双数(含0)时 e.CellStyle.BackColor = Color.White; } else { e.CellStyle.BackColor = Color.Honeydew; } e.CellStyle.SelectionBackColor = Color.Gray; // 选中单元格时,背景色 e.CellStyle.Alignment = DataGridViewContentAlignment.MiddleCenter; //单位格内数据对齐方式 }
    复制代码

     

    显示效果:

  • 相关阅读:
    C# 导出 Excel 自定义输出格式
    ONE路由协议模块分析与应用
    2440(ARM9) L3G4200D ADXL345 裸机程序
    C# SerialPort.close() bug解决方法
    C++ Primer 第五章 表达式
    C++ Primer 第一章 快速入门
    C++ Primer 第二章 变量和基本类型
    虚拟机virtualbox中挂载新硬盘
    C++ Primer 第四章 数组与指针
    C++ Primer 第三章 标准库类型
  • 原文地址:https://www.cnblogs.com/nimorl/p/9494452.html
Copyright © 2020-2023  润新知