• 数据绑定

    • 直接指定源数据(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.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;
          }
          }

WinForm中DataGridView的使用(一) - 基本使用的更多相关文章

  1. winform中dataGridView单元格根据值设置新值,彻底解决绑定后数据类型转换的困难

    // winform中dataGridView单元格在数据绑定后,数据类型更改困难,只能迂回实现.有时候需要将数字变换为不同的文字描述,就会出现int32到string类型转换的异常,借助CellFo ...

  2. winform中dataGridView隔行显示不同的背景色,鼠标移动上显示不同颜色,离开后变回原色

    winform中dataGridView隔行显示不同的背景色,鼠标移动上显示不同颜色,离开后变回原色 先设置奇数行颜色,这个有个自带的属性AlternatingRowsDefaultCellStyle ...

  3. 【接上一篇】winform中dataGridView高度和宽度自适应填充完数据的高度和宽度,即dataGridView根据数据自适应大小

    上一篇:winform中dataGridView高度自适应填充完数据的高度 winform中dataGridView高度自适应填充完数据的高度,就是dataGridView自身不产生滚动条,自己的高度 ...

  4. winform中dataGridView高度自适应填充完数据的高度

    // winform中dataGridView高度自适应填充完数据的高度,就是dataGridView自身不产生滚动条,自己的高度是根据数据的多少而变动. 在load的时候,数据绑定后,加上如下代码: ...

  5. C# Winform中DataGridView的DataGridViewCheckBoxColumn使用方法

    下面介绍Winform中DataGridView的DataGridViewCheckBoxColumn使用方法: DataGridViewCheckBoxColumn CheckBox是否选中 在判断 ...

  6. WinForm中DataGridView复制选中单元格内容解决方案

    WinForm中DataGridView鼠标选中单元格内容复制方案 1.CTR+C快捷键复制 前提:该控件ClipboardCopyMode属性设置值非Disable: 2.鼠标框选,自定义代码实现复 ...

  7. winform中DataGridView实现分页功能

    WinForm轻松实现自定义分页 (转载) WinForm轻松实现自定义分页 (转载)   转载至http://xuzhihong1987.blog.163.com/blog/static/26731 ...

  8. Winform 中DataGridView控件添加行标题

    有很多种方法. 1.可以在DataGridView控件中的RowStateChanged事件改变行标题单元格的值(Row.HeaderCell.Value) /// <summary> / ...

  9. Winform 中DataGridView的checkbox列,当修改checkbox状态时实时获得其状态值

    不知道大家有没有这样的经验,当点击或者取消datagridview的checkbox列时,比较难获得其状态是选中还是未选中,进而不好进行其它操作,下面就列出它的解决办法: 主要用到了DataGridV ...

  10. WinForm中DataGridView显示更新数据--人性版

    using System; using System.Collections.Generic; using System.ComponentModel; using System.Data; usin ...

随机推荐

  1. Python之路(第十一篇)装饰器

    一.什么是装饰器? 装饰器他人的器具,本身可以是任意可调用对象,被装饰者也可以是任意可调用对象. 强调装饰器的原则:1 不修改被装饰对象的源代码 2 不修改被装饰对象的调用方式 装饰器的目标:在遵循1 ...

  2. Java虚拟机的相关笔记

    1.垃圾GC回收事件Minor GC(只清除新生代),Full GC(清除新生代和老年代),Major GC(清除新生.老年代和持久代). 2.堆分为新生代.老年代和持久代,持久代一般存放静态文件. ...

  3. Office 365 API Tools预览版已提供下载

    Office 365 API Tools预览版地址:http://visualstudiogallery.msdn.microsoft.com/7e947621-ef93-4de7-93d3-d796 ...

  4. spring自动类型转换========Converter和PropertyEditor

    Spring有两种自动类型转换器,一种是Converter,一种是propertyEditor. 两者的区别:Converter是类型转换成类型,Editor:从string类型转换为其他类型. 从某 ...

  5. 【转】手动释放linux os buff/cache

    手动释放linux内存cache和脚本定时释放 标签: linuxcache脚本bufferwindows磁盘 2011-12-04 08:44 12799人阅读 评论(2) 收藏 举报  分类: l ...

  6. MySql常用命令集

    MySql 常用命令集 Mysql常用命令 show databases; 显示数据库 create database name; 创建数据库 use databasename; 选择数据库 drop ...

  7. kafka 支持发布订阅

    概述 一般消息队列的是实现是支持两种模式的,即点对点,还有一种是topic发布订阅者模式,比如ACTIVEMQ.KAFKA也支持这两种模式,但是实现的原理不一样. KAFKA 的消息被读取后,并不是马 ...

  8. 委托构造函数(c++11)

    1.概念 1)委托构造函数也是构造函数,它也有形参列表,它将实参传递给其他的构造函数来初始化类对象,像是把自己的一些(或者全部)构造职责委托给其他构造函数一样

  9. IntelliJ IDEA 2017版 spring-boot2.0.4+mybatis+Redis处理高并发,穿透问题

    一.当采用reddis缓存的时候,如果同时,一万次访问,那么就会有10000次访问数据库所以就会对数据库造成巨大压力,这时候,就要用到线程 1.方法体上加锁(优点,防护住了并发锁,缺点降低了内存效率) ...

  10. 通过Windows API实现的MDI简易程序

    ## #include <windows.h> #include <tchar.h> HINSTANCE hInst; ATOM WindowRegister(WNDPROC ...