当前位置: 移动技术网 > IT编程>开发语言>c# > C#窗体控件DataGridView常用设置

C#窗体控件DataGridView常用设置

2019年07月18日  | 移动技术网IT编程  | 我要评论

在默认情况下,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 为枚举类型:

 

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; //单位格内数据对齐方式

  }

显示效果:

 以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持移动技术网。

如对本文有疑问, 点击进行留言回复!!

相关文章:

验证码:
移动技术网