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 ...
随机推荐
- .net上传文件,利用npoi读取文件信息到datatable里
整理代码,.net上传文件,利用npoi读取文件到datatable里,使用了FileUpload控件,代码如下: protected void Button1_Click(object sender ...
- 2017/2/13:springMVC拦截器的使用
一.定义Interceptor实现类(主要是实现Handlerceptor接口) SpringMVC 中的Interceptor 拦截请求是通过HandlerInterceptor 来实现的.在Spr ...
- 嵌入式C编程代码优化笔记
[优化永远是追求某种平衡而不是走极端,优化是有侧重点的,优化是一门平衡的艺术,它往往要以牺牲程序的可读性或者增加代码长度为代价] 1.选择合适的算法和数据结构 选择一种合适的数据结构很重要,如果在一堆 ...
- 【Web】网页清除浮动的方法
网页中,经常用浮动的div来布局,但是会出现父元素因为子元素浮动引起内部高度为0的问题,为了解决这个问题,我们需要清除浮动,下面介绍4中清除浮动的方法. 在CSS中,clear属性用户清除浮动,语法: ...
- php使用include报错require_once(../include.php): failed to open stream: No such file or directo
引入路径的问题,建议加入include_once $_SERVER['DOCUMENT_ROOT']."/include.php";意思是获取网站根目中的include.php 截 ...
- 2019.01.23 hdu1693 Eat the Trees(轮廓线dp)
传送门 题意简述:给一个有障碍的网格图,问用若干个不相交的回路覆盖所有非障碍格子的方案数. 思路:轮廓线dpdpdp的模板题. 同样是讨论插头的情况,只不过没有前一道题复杂,不懂的看代码吧. 代码: ...
- Methods to reduce the number of pipeline stages
Several techniques have been proposed to reduce the number of pipeline stages. We categorize them in ...
- AngularJS实战之路由ui-view
1. 路由(ui-router) 1.1. 环境 1) angular.min.js 2) angular-ui-router-0.2.10.js 3) 确保确保包含ui.router为模块依赖关系. ...
- 如何批量下载网站中的超链接(一次性下载网页中所有可能的PDF文件)
最近公司在做工程项目,实现文件批量下载. 网上找了很久,发现网上的代码都有相似的问题,不过最终还是让我找到了一个符合的项目. 工程: 进行项目文件下载功能分析,弄清楚文件批量下载的原理,提供的数据支持 ...
- 关于Lambda
1. 查询时,包含关联子对象.如: 数据库中包含表Father和Son,映射实体如下: public class Father { public string Name{get;set;} publi ...