WinForm中DataGridView的使用(一) - 基本使用
- 数据绑定
- 直接指定源数据(List<T>):this.DataSource = data;
- 通常也可以直接指定DataTable类型的数据
DataTable dt = new DataTable();
DataColumn dc1 = new DataColumn(_column1Name, Type.GetType("System.String"));
dt.Columns.Add(dc1);
foreach (string searchText in VisualXmlApp.Instance.searchHistoryGridView.Take())
{
DataRow dr = dt.NewRow();
dr[_column1Name] = searchText;
dt.Rows.Add(dr);
}
this.dgvDataSourceSearchHistory.DataSource = dt;
- 自定义列
- 取消自动生成列:this.AutoGenerateColumns = false;
- 自定义列数、列名、列宽权重、列填充
this.Columns.Clear();
this.ColumnCount = ;
this.Columns[].Name = "Column 1";
this.Columns[].DataPropertyName = "VarName";
this.Columns[].FillWeight = ;
this.Columns[].Name = "Column 2";
this.Columns[].DataPropertyName = "VarPath";
this.Columns[].FillWeight = ;
this.Columns[].Name = "Column 2";
this.Columns[].FillWeight = ;
- 样式
- 整体背景色(当窗口变大时,空白处的颜色)
- this.BackgroundColor = DataSourceUIParams.WindowBackColor;
- 边框
- 风格
- DataGridView.BorderStyle
- BorderStyle 枚举: FixedSingle(单线,默认)、Fixed3D、None
- 颜色(所有边框,含普通数据行和头部)
- this.GridColor = Color.FromArgb(173, 190, 203);
- 如果要头部生效,别忘了取消系统风格影响:this.EnableHeadersVisualStyles=false;
- 默认是 ControlDarkDark 。但是只有在 CellBorderStyle 被设定为 Single、SingleHorizontal、SingleVertical 的条件下才能改变其边框线的颜色。
- 如果是自定义了一个控件继承自DataGridView,那么即使在这个控件中设置了不显示边框,在父控件中仍然需要再设置一次其BorderStyle = BorderStyle.None;
- 其他可参考(如颜色、四个方位边框的单独设置):https://blog.csdn.net/yunhaic/article/details/7176015
- 风格
- 头部
- 取消使用系统风格:this.EnableHeadersVisualStyles = false;
- 行头
- 取消显示行头
- this.RowHeadersVisible = false;
- 边框
- 风格
- 直接设置RowHeadersBorderStyle,默认是DataGridViewHeaderBorderStyle.Raised,可改为Single、None等。属性设定值是DataGridViewHeaderBorderStyle枚举的值
- 风格
- 取消显示行头
- 列头
- 取消显示列头
- this.ColumnHeadersVisible = false;
- 高度
- 先把ColumnHeadersHeightSizeMode从默认的AutoSize设置为EnableResizing
- 再用ColumnHeadersHeight直接设置高度
- 注:代码构造函数中直接设置这两个属性也可以
- 注:将DataGridView设置固定高度,并自动显示滚动条时,如果Header高度是AutoSize的,可能会使最后一行显示不全
- 字体
- 边框
- 风格
- 直接设置ColumnHeadersBorderStyle,默认是DataGridViewHeaderBorderStyle.Raised,可改为Single、None等。属性设定值是DataGridViewHeaderBorderStyle枚举的值
- 同样,ColumnHeadersBorderStyle只能设定单元格全部边框线的式样。要单独改变单元格某一边边框式样的话,需要用到设定行头单元格的属性是: RowHeadersBorderStyle, 设定列头单元格属性是:ColumnHeadersBorderStyle
- 风格
- 取消显示列头
- 数据行
- 高度
- this.RowTemplate.Height = 30;
- 奇偶行
- 背景色
- this.AlternatingRowsDefaultCellStyle.BackColor = Color.FromArgb(223, 230, 237);
- this.RowsDefaultCellStyle.BackColor = Color.White;
- 背景色
- 边框
- 风格
- 直接设置CellBorderStyle,默认为BorderStyle.FixedSingle,但这个时候底边框有可能消失,可以考虑改为BorderStyle.Fixed3D
- CellBorderStyle只能设定单元格全部边框线的式样。要单独改变单元格某一边边框式样的话,需要用到DataGridView.AdvancedCellBorderStyle属性。
- 风格
- 高度
- 整体背景色(当窗口变大时,空白处的颜色)
- 是否可编辑、新增、删除
- this.ReadOnly = true;
- this.AllowUserToAddRows = false;
- this.AllowUserToDeleteRows = false;
- 是否可调整列宽、行宽
- this.AllowUserToResizeColumns = false;
this.AllowUserToResizeRows = false;
- this.AllowUserToResizeColumns = false;
- 是否可选中及选中模式
- 是否可多选:this.MultiSelect = false;
- 设置选中模式
- 直接设置SelectionMode属性,包括DataGridViewSelectionMode.FullRowSelect等选项
- 取消首行或首个单元格的默认选中
- 在DataGridView的RowsPrePaint事件处理函数中
private void RowsPrePaintHandler(object sender, DataGridViewRowPrePaintEventArgs e)
{
int index = e.RowIndex; // cancel default selected first row
if (index == )
{
this.Rows[index].Selected = false;
}
}
- 在DataGridView的RowsPrePaint事件处理函数中
WinForm中DataGridView的使用(一) - 基本使用的更多相关文章
- winform中dataGridView单元格根据值设置新值,彻底解决绑定后数据类型转换的困难
// winform中dataGridView单元格在数据绑定后,数据类型更改困难,只能迂回实现.有时候需要将数字变换为不同的文字描述,就会出现int32到string类型转换的异常,借助CellFo ...
- winform中dataGridView隔行显示不同的背景色,鼠标移动上显示不同颜色,离开后变回原色
winform中dataGridView隔行显示不同的背景色,鼠标移动上显示不同颜色,离开后变回原色 先设置奇数行颜色,这个有个自带的属性AlternatingRowsDefaultCellStyle ...
- 【接上一篇】winform中dataGridView高度和宽度自适应填充完数据的高度和宽度,即dataGridView根据数据自适应大小
上一篇:winform中dataGridView高度自适应填充完数据的高度 winform中dataGridView高度自适应填充完数据的高度,就是dataGridView自身不产生滚动条,自己的高度 ...
- winform中dataGridView高度自适应填充完数据的高度
// winform中dataGridView高度自适应填充完数据的高度,就是dataGridView自身不产生滚动条,自己的高度是根据数据的多少而变动. 在load的时候,数据绑定后,加上如下代码: ...
- C# Winform中DataGridView的DataGridViewCheckBoxColumn使用方法
下面介绍Winform中DataGridView的DataGridViewCheckBoxColumn使用方法: DataGridViewCheckBoxColumn CheckBox是否选中 在判断 ...
- WinForm中DataGridView复制选中单元格内容解决方案
WinForm中DataGridView鼠标选中单元格内容复制方案 1.CTR+C快捷键复制 前提:该控件ClipboardCopyMode属性设置值非Disable: 2.鼠标框选,自定义代码实现复 ...
- winform中DataGridView实现分页功能
WinForm轻松实现自定义分页 (转载) WinForm轻松实现自定义分页 (转载) 转载至http://xuzhihong1987.blog.163.com/blog/static/26731 ...
- Winform 中DataGridView控件添加行标题
有很多种方法. 1.可以在DataGridView控件中的RowStateChanged事件改变行标题单元格的值(Row.HeaderCell.Value) /// <summary> / ...
- Winform 中DataGridView的checkbox列,当修改checkbox状态时实时获得其状态值
不知道大家有没有这样的经验,当点击或者取消datagridview的checkbox列时,比较难获得其状态是选中还是未选中,进而不好进行其它操作,下面就列出它的解决办法: 主要用到了DataGridV ...
- WinForm中DataGridView显示更新数据--人性版
using System; using System.Collections.Generic; using System.ComponentModel; using System.Data; usin ...
随机推荐
- DOM BOM 常用API小记
DOM 1.元素节点: 元素节点element: 更精确的获得元素的标签名(全大写) 属性节点attribute: 属性名 文本节点text: #text 注释节点document:#document ...
- jquery动态出操作select
var citys = {1:'北京',2:'上海',3:'广州',4:'深圳'}; $("#city option:gt(0)").remove(); for(var k in ...
- POI导出大量数据的简单解决方案
说明:我的电脑 2.0CPU 2G内存 能够十秒钟导出 20W 条数据 ,12.8M的excel内容压缩后2.68M 我们知道在POI导出Excel时,数据量大了,很容易导致内存溢出.由于Excel ...
- jdom解析xml
这次把代码整理了一下,打包发上来了,程序中需要用到的jar包也一起打在里面了,有兴趣的朋友可以解压后直接导入的eclipse里运行! xml是一种广为使用的可扩展标记语言,java中解析xml的方式有 ...
- 如何上传Packages到PyPI并批量抓取
1.如何上传包到PyPI ? 更新中... 2.批量抓取simple网站第三方模块 https://pypi.python.org/simple/ 3. 第三方模块的安装和使用 python set ...
- Hibernate validator的一些额外特性
分组验证及分组顺序 如果我们想在新增的情况验证id和name,而修改的情况验证name和password,怎么办? 那么就需要分组了. 首先定义分组接口://分组接口就是两个普通的接口,用于标识,类似 ...
- CollisionFlags
CollisionFlags是CharactorController的返回值,表示碰撞的信息 Values: None Sides Above Below function Update () { v ...
- java web各个技术细节总结
HTML 非表单标签 1.b 粗体 u 下划线 i 斜体 del 删除效果 2.a 超链接 href target=-blank 3.img 图片 4.frameset(frame) 框架 ...
- jquery遍历之parent()与parents()的区别 及 parentsUntil() 方法
来自:http://blog.csdn.net/zm2714/article/details/8117746 .parent(selector) 获得当前匹配元素集合中每个元素的父元素,由选择器筛选( ...
- hdu-1043(八数码+bfs打表+康托展开)
参考文章:https://www.cnblogs.com/Inkblots/p/4846948.html 康托展开:https://blog.csdn.net/wbin233/article/deta ...