一、引言

Datagridview控件在winform开发中还是比较常用,一般的数据库系统都会使用它,但是想要友好的展示数据,形成良好的用户界面,那么就要对c#库中默认的Datagridview设置进行更改,以达到友好界面的需求。

下面就介绍一下Datagridview常见的用法。

二、Datagridview设置

1、列设置

a)、列的宽度铺满这个控件

  设置如下:把AutoSizeColumnsMode=Fill;//可以在属性窗口中设置

b)、列名居中

代码如下:

this.dataGridView1.ColumnHeadersDefaultCellStyle.Alignment = DataGridViewContentAlignment.MiddleCenter; //设置表头的格式(居中显示)

c)、禁止编辑某列

代码如下: 

 //禁止某一些列编辑
dataGridView1.ReadOnly = false;
foreach (DataGridViewColumn c in dataGridView1.Columns)
{
if (c.Index != )
c.ReadOnly = true;
}

d)、禁止列点击排序

代码如下:

 //不能被排序
foreach (DataGridViewColumn c in dataGridView1.Columns)
{
c.SortMode = DataGridViewColumnSortMode.NotSortable;
}

e)、设置列的字体

 this.dataGridView1.RowsDefaultCellStyle.Font = new Font("宋体", );

f)、设置列宽

this.dataGridView1.Columns[].Width = ; this.dataGridView1.Columns[].Width = ;

g)、设置列显示模式

需要将第一列的单元格的内容全部显示出来,代码如下:

this.dataGridView1.Columns[].AutoSizeMode = DataGridViewAutoSizeColumnMode.AllCells ;

h)、禁止最左边的空列头显示

 this.dgvSymbol.RowHeadersVisible = false;

2、行设置

a)、设置字体

代码如下:

this.dataGridView1.ColumnHeadersDefaultCellStyle.Font = new Font("仿宋", ,FontStyle.Bold );

b)、改变默认的选中的颜色

代码如下:

 dataGridView1.DefaultCellStyle.SelectionBackColor = Color.Black;
dataGridView1.DefaultCellStyle.SelectionForeColor = Color.White;

c)、允许每个单元格多行显示

代码如下:

this.dataGridView1 .DefaultCellStyle.WrapMode = DataGridViewTriState.True;

d)、设置每个单元格居中

代码如下:

foreach (DataGridViewColumn item in this.dataGridView1.Columns)
{
item.DefaultCellStyle.Alignment = DataGridViewContentAlignment.MiddleCenter;//设置每个单元格的格式(居中)
}

e)、清除选择的单元格

代码如下:

foreach (DataGridViewCell c in this.dataGridView1.SelectedCells)
{
c.Selected = false;
}

3、在每行的左边为每行添加一个从1开始递增的序号

效果如下:

首先为Datagridview控件添加一个单元格绘制的事件RowPostPaint,然后在该事件下面添加一些绘制的代码就行了,代码如下:

private void dataGridView1_RowPostPaint(object sender, DataGridViewRowPostPaintEventArgs e)
{
SolidBrush b = new SolidBrush(this.dataGridView1.RowHeadersDefaultCellStyle.ForeColor);
e.Graphics.DrawString((e.RowIndex + ).ToString(System.Globalization.CultureInfo.CurrentUICulture), this.dataGridView1.DefaultCellStyle.Font, b, e.RowBounds.Location.X + , e.RowBounds.Location.Y + );
e.Graphics.FillRectangle(Brushes.White , new Rectangle(new Point(e.RowBounds.Location.X + , e.RowBounds.Location.Y + ), new Size(, )));//隐藏每行前面的图标
}

4、如何为列添加其他类型的列(而不是DataGridViewTextBoxColumn)并且绑定相应的数据源

一般的将数据查询所获取的表格DataTable对象绑定到Datagridview表格,我们只写一句代码:this.dataGridView1.DataSource=dtQueryResult;这样做虽然方便,但是却不人性化,显示的结果都是显示在DataGridViewTextBoxColumn中,而且列的标题都是查询中数据库的字段,并不是我们想要的显示的字段,那么如何根据数据库查询的表格数据对Datagridview的列的类型及其显示进行名称进行定制呢?

假设从数据库中查询出来的数据列有(id,eventMark,timeBlock,typeName,isComplete(bit))四个字段。

显示的要求

  • 1、id不让显示
  • 2、eventMark显示名称为:时间、timeBlock显示名称为:时间段、typeName显示名称为:类型名称、isComplete显示名称为:状态
  • 2、typeName的类型为DataGridViewComboBoxColumn类型,并绑定数据源,isComplete列显示的类型为DataGridViewCheckBoxColumn类型。

根据设置代码如下:

第一步还是不变,依然是绑定数据源this.dataGridView1.DataSource=dtQueryResult。

            this.dataGridView1.AutoGenerateColumns = false;

            DataGridViewTextBoxColumn dtEvent = new DataGridViewTextBoxColumn();
dtEvent.DataPropertyName = "eventMark";
dtEvent.HeaderText = "事件";
dataGridView1.Columns.Add(dtEvent); //添加timeBlock项
DataGridViewTextBoxColumn dtTime = new DataGridViewTextBoxColumn();
dtTime.DataPropertyName = "timeBlock";
dtTime.HeaderText = "时间段";
dataGridView1.Columns.Add(dtTime); //添加typeName项
DataGridViewComboBoxColumn dtType = new DataGridViewComboBoxColumn();
dtType.DataPropertyName = "typeName";
dtType.HeaderText = "类型";
dtType.DataSource = TypeNames.GetTypeNames();//绑定combox显示的数据源
dataGridView1.Columns.Add(dtType);
//添加isComplete项
DataGridViewCheckBoxColumn dtCheck = new DataGridViewCheckBoxColumn();
dtCheck.DataPropertyName = "isComplete";
dtCheck.HeaderText = "状态";
dataGridView1.Columns.Add(dtCheck);

三、总结

Datagridview的用法远远不及上述说的那么一些,还有很多实用的功能值得我们的去探索,包括他的重绘、事件处理等等。还可以根据自己的项目的需求可以对Datagridview控件进行定制,可以实现各种你意想不到的显示效果。

尽等你去发掘··············

关于Datagridview控件用法的一些总结的更多相关文章

  1. 关于Datagridview控件用法的一些总结(设置列chicun)

    1. 关于Datagridview控件用法的一些总结:http://www.cnblogs.com/mingjiatang/p/4968049.html

  2. DataGridView控件用法二:常用属性

    通常会设置的DataGridView的属性如下: AllowUserToAddRows - False指示是否向用户显示用于添加行的选项,列标题下面的一行空行将消失.一般让其消失.AllowUserT ...

  3. WinForm开发(1)——DataGridView控件(1)——C# DataGridView控件用法介绍

    DataGridView控件在实际应用中非常实用,特别需要表格显示数据时.可以静态绑定数据源,这样就自动为DataGridView控件添加相应的行.假如需要动态为DataGridView控件添加新行, ...

  4. DataGridView控件用法合集

    1.当前的单元格属性取得.变更 Console.WriteLine(DataGridView1.CurrentCell.Value) Console.WriteLine(DataGridView1.C ...

  5. DataGridView 控件用法(可能不是很全面,因为这是自己常常用到的一些小总结):

    一.DataGridView属性设置 1.我们单击选中行的时候,默认是选择一个单元格,不能选择一整行,我们只需设置DataGridView的属性SelectionMode为FullRowSelect ...

  6. winform DataGridView控件判断滚动条是否滚动到当前已加载的数据行底部 z

    http://www.zuowenjun.cn/post/2015/05/20/162.html 判断 DataGridView控件滚动条是否滚动到当前已加载的数据行底部,其实方法很简单,就是为Dat ...

  7. DataGridView控件

    DataGridView控件 DataGridView是用于Windows Froms 2.0的新网格控件.它可以取代先前版本中DataGrid控件,它易于使用并高度可定制,支持很多我们的用户需要的特 ...

  8. DataGridView控件-[引用]

    DataGridView控件 DataGridView是用于Windows Froms 2.0的新网格控件.它可以取代先前版本中DataGrid控件,它易于使用并高度可定制,支持很多我们的用户需要的特 ...

  9. DataGridView控件使用大全说明-各种常用操作与高级操作

    DataGridView控件 DataGridView是用于Windows Froms 2.0的新网格控件.它可以取代先前版本中DataGrid控件,它易于使用并高度可定制,支持很多我们的用户需要的特 ...

随机推荐

  1. SSH免密码远程登录Linux

    1. 有A,B两台机(Linux/unix), 要想从A用ssh远程登录到B上(假设各自的IP,A:192.168.100:B:192.168.1.104). 2. 在A机上,用“ssh-keygen ...

  2. CSS3的三大特性

    在学习CSS 的时候,我们必须要熟练和理解CSS 的三大特性,那么CSS 的三大特性又是什么呢? CSS 的三大特性:层叠 继承 优先级  ,CSS 三大特性是我们学习CSS 必须掌握的三个特性. 首 ...

  3. 在Ubuntu中增加root用户登录

    一:增加root用户登录 1.打开终端,输入:sudo gedit /usr/share/lightdm/lightdm.conf.d/50-ubuntu.conf 2.在弹出的编辑框里输入:gree ...

  4. springMvc的执行流程(源码分析)

    1.在springMvc中负责处理请求的类为DispatcherServlet,这个类与我们传统的Servlet是一样的.我们来看看它的继承图 2. 我们发现DispatcherServlet也继承了 ...

  5. css style 标签可编辑

    一次偶然在鑫大技术博客上发现  style  标签配合contenteditable 可编辑属性 实现动态编辑css 这里我就回顾了下  contenteditable  可编辑属性 (这个属性并无浏 ...

  6. 【GDKOI2017】小队任务 莫比乌斯反演+杜教筛

    题目大意:给你n,求$\sum_{i=1}^{n}\sum_{j=i}^{n}[gcd(i,j)=1](i+1)(j+1)$ 子任务一:暴力 子任务二:$T=50000,n≤10^7$ 子任务三:$T ...

  7. sqlCAST使用详解

    (1).CAST()函数的参数是一个表达式,它包括用AS关键字分隔的源值和目标数据类型.以下例子用于将文本字符串'12'转换为整型: SELECT CAST('12' AS int) (2).返回值是 ...

  8. springboot打包成jar包后找不到xml,找不到主类的解决方法

    springboot打包成jar包后找不到xml,找不到主类的解决方法 请首先保证你的项目能正常运行(即不打包的时候运行无误),我们在打包时经常遇到如下问题: springboot打包成jar包后找不 ...

  9. Unable to handle kernel NULL pointer dereference at virtual address 00000000问题的解决

    今天在编译好内核模块后,安装内核模块memdev.ko的时候,出现了Unable to handle kernel NULL pointer dereference at virtual addres ...

  10. 以整体思维看问题:解决单页应用,系统角色请求覆盖身份唯一标识(本项目中是session_id命名的)发送请求问题

    以前都是开始一段废话的,现在直接进入主题,首先介绍一下一些概念: 单页应用: 优点: 具有桌面应用的即时性.网站的可移植性和可访问性. 用户体验好.快,内容的改变不需要重新加载整个页面,web应用更具 ...