欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C#開(kāi)發(fā)WinForm之DataGridView開(kāi)發(fā)詳解

 更新時(shí)間:2021年01月13日 14:19:10   作者:陳袁  
這篇文章主要介紹了C#開(kāi)發(fā)WinForm之DataGridView開(kāi)發(fā)詳解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧

前言

DataGridView是開(kāi)發(fā)Winform的一個(gè)列表展示,類似于表格。學(xué)會(huì)下面的基本特征用法,再輔以經(jīng)驗(yàn),基本功能開(kāi)發(fā)沒(méi)問(wèn)題。

基本的數(shù)據(jù)渲染

根據(jù)提供的數(shù)據(jù)展示出效果。

提供給DataGridView數(shù)據(jù)源有很多方式,大致有如下三種:

直接增加,每個(gè)單元格類型都是DataGridViewTextBoxCell

int index=this.dataGridView1.Rows.Add();
this.dataGridView1.Rows[index].Cells[0].Value = "1";
this.dataGridView1.Rows[index].Cells[1].Value = "2";
this.dataGridView1.Rows[index].Cells[2].Value = "3";

直接增加一行,在行上的每天單元格內(nèi)添加數(shù)據(jù),缺點(diǎn)是太單一

直接增加,但我們可以指定單元格類型

DataGridViewRow row = new DataGridViewRow();
DataGridViewTextBoxCell textboxcell = new DataGridViewTextBoxCell();
textboxcell.Value = "aaa";
row.Cells.Add(textboxcell);
DataGridViewComboBoxCell comboxcell = new DataGridViewComboBoxCell();
row.Cells.Add(comboxcell);
dataGridView1.Rows.Add(row);

可選的類型如下圖:

在這里插入圖片描述

使用vo對(duì)象

上面2種都不是我想要的,因?yàn)榱斜碚故镜臄?shù)據(jù)大部分情況下是復(fù)雜的后臺(tái)回傳的數(shù)據(jù)。所以我建議使用Vo。
新建InfoVo.cs類

public class InfoVo
 {
  /// <summary>
  /// 
  /// </summary>
  public string uidItem { get; set; }
  /// <summary>
  /// 
  /// </summary>
  public string uidItemRevision { get; set; }
  /// <summary>
  /// 
  /// </summary>
  public string primaryTag { get; set; }
 }

構(gòu)造一個(gè)List,將InfoVo放進(jìn)List對(duì)象里,然后將List對(duì)象賦值給dataGridView.DataSource即可。
在窗體的Load事件里添加如下代碼

private void SearchInfo_Load(object sender, EventArgs e)
  {
  	List<InfoVo> list = new List<InfoVo>();
    list.Add(new InfoVo(){ uidItem="1", uidItemRevision ="1", primaryTag ="1"});
    list.Add(new InfoVo(){ uidItem="2", uidItemRevision ="2", primaryTag ="2"});
    dataGridView.AutoGenerateColumns = false;
    dataGridView.DataSource = null;
    dataGridView.DataSource = list;
  }

直接賦值dataGridView.DataSource = list即可。這里的AutoGenerateColumns是禁止dataGridView自動(dòng)根據(jù)vo屬性創(chuàng)建列。

在窗體上選中DataGridView,在屬性面板里點(diǎn)擊Columns選項(xiàng)。如下圖

在這里插入圖片描述

在打開(kāi)的面板里,我們可以創(chuàng)建列。選擇是否可見(jiàn),設(shè)置抬頭
DataPropertyName:指定列綁定的數(shù)據(jù)源屬性字段。
在DolumnType里我們可以指定單元格類型,如下圖

在這里插入圖片描述

比如下拉框,或者單元框。
至此,我們可以渲染出DataGridView組件里,下面看一些屬性。

dataGridView

列寬自適應(yīng)

foreach (DataGridViewColumn column in dataGridView.Columns)
 {
  column.AutoSizeMode = DataGridViewAutoSizeColumnMode.AllCells;
 }

成員名稱 說(shuō)明
NotSet 列的大小調(diào)整行為從DataGridView.AutoSizeColumnsMode 屬性繼承。
None 列寬不會(huì)自動(dòng)調(diào)整。
AllCells 調(diào)整列寬,以適合該列中的所有單元格的內(nèi)容,包括標(biāo)題單元格。
AllCellsExceptHeader 調(diào)整列寬,以適合該列中的所有單元格的內(nèi)容,不包括標(biāo)題單元格。
DisplayedCells 調(diào)整列寬,以適合當(dāng)前屏幕上顯示的行的列中的所有單元格的內(nèi)容,包括標(biāo)題單元格。
DisplayedCellsExceptHeader 調(diào)整列寬,以適合當(dāng)前屏幕上顯示的行的列中的所有單元格的內(nèi)容,不包括標(biāo)題單元格。
ColumnHeader 調(diào)整列寬,以適合列標(biāo)題單元格的內(nèi)容。
Fill 調(diào)整列寬,使所有列的寬度正好填充控件的顯示區(qū)域,只需要水平滾動(dòng)保證列寬在DataGridViewColumn.MinimumWidth屬性值以上。相對(duì)列寬由相對(duì)DataGridViewColumn.FillWeight屬性值決定。

如果想讓列寬能按比例填充顯示區(qū)域則 column.AutoSizeMode = DataGridViewAutoSizeColumnMode.Fill;

禁止縮放單元格大小

2個(gè)屬性

  • AllowUserToResizeColumns:true:禁止縮放列
  • AllowUserToResizeRows:true:禁止縮放行

用戶自定義列的順序

用戶可以拖動(dòng)的方式排序列展示
AllowUserToOrderColumns:true

是否可以編輯單元格

  • 窗體的ReadOnlyfalse
  • 在Columns彈出的列編輯窗口里,選擇列的ReadOnlyfalse
  • SelectionModeRowReadSelect(這是默認(rèn)值)

行頭,列頭不顯示

在屬性面板里選中RowheadersVisible和ColumnHeadersVisible,置為false

列表顯示不完全,必需鼠標(biāo)移到組件上才能顯示的bug

RowheadersVisible置為false即可。

行頭顯示行號(hào)

RowStateChanged事件添加監(jiān)聽(tīng),(在屬性面板右邊閃電圖標(biāo)下找)。

private void dataGridView1_RowStateChanged(object sender, DataGridViewRowStateChangedEventArgs e)
{
 //顯示在HeaderCell上
 for (int i = 0; i < this.dataGridView1.Rows.Count; i++)
 {
  DataGridViewRow r = this.dataGridView1.Rows[i];
  r.HeaderCell.Value = string.Format("{0}", i + 1);
 }
 this.dataGridView1.Refresh();
}

行號(hào)沒(méi)有完全顯示出來(lái)的解決辦法是將DataGridViewRowHeadersWidthSizeMode屬性設(shè)置為AutoSizeToAllHeaders、AutoSizeToDisplayedHeaders或者AutoSizeToFirstHeader。

禁止自動(dòng)創(chuàng)建列

如果我們提供的vo對(duì)象,dataGrid會(huì)自動(dòng)根據(jù)屬性創(chuàng)建列,這不是我想要的,我希望能控制顯示。如下設(shè)置即可
dataGridView.AutoGenerateColumns = false;

修改單元格類型

單元格可以顯示文件,也可以顯示單元框,下拉框,圖片和超鏈拉。只要在編輯列窗口里選擇ColumnType下拉框,選擇一下即可。當(dāng)然選擇的不同,數(shù)據(jù)設(shè)置不同,比如
單選框DataGridViewCheckBoxColumn如下

在這里插入圖片描述

下拉框DataGridViewComboBoxColumn

在這里插入圖片描述

選中模式

可以指定選中是整個(gè)行被選中還是每個(gè)小單元格被選中
SelectionMode,全部可選如下

在這里插入圖片描述

其它

當(dāng)然還有其它,只要我們熟悉,在屬性面板上幾乎都能找到。

選中事件

CellClick是選中事件,不用它即可,不要用CellContentClick,因?yàn)槿绻麊卧駸o(wú)內(nèi)容,這個(gè)CellContentClick事件不會(huì)觸發(fā)。

取得當(dāng)前單元格內(nèi)容 :DataGridView1.CurrentCell.Value
取得當(dāng)前單元格的列 Index:DataGridView1.CurrentCell.ColumnIndex
取得當(dāng)前單元格的行 Index:DataGridView1.CurrentCell.RowIndex
取得當(dāng)前行:dataGridView.CurrentRow;
獲得綁定的vo

DataGridViewRow dataGridViewRow = dataGridView.CurrentRow;
   InfoVo infoVo = dataGridViewRow.DataBoundItem as InfoVo ;
   infoVo .uidItemRevision ;

如果表格可編輯,那么編輯完表格會(huì)同步更新DataBoundItem綁定的vo對(duì)象

遍歷列表里所有單元格

	foreach (DataGridViewRow item in dataGridView.Rows)
   {
     //item是每行的對(duì)象,cells是單元格集合
    if (null != item.Cells[0].Value && (Boolean)item.Cells[0].Value)
    {
			item.Cells[0].Value.toString();
		}
	}

使用 DataGridView.CurrentCellAddress 屬性(而不是直接訪問(wèn)單元格)來(lái)確定單元格所在的
行: DataGridView.CurrentCellAddress.Y
列: DataGridView.CurrentCellAddress.X 。

當(dāng)前的單元格可以通過(guò)設(shè)定 DataGridView 對(duì)象的 CurrentCell 來(lái)改變??梢酝ㄟ^(guò) CurrentCell 來(lái)設(shè)定
DataGridView 的激活單元格。將 CurrentCell 設(shè)為 Nothing(null) 可以取消激活的單元格。

DataGridView DataGridViewCheckBoxColumn編輯時(shí)實(shí)時(shí)觸發(fā)事件

正常響應(yīng)CellValueChanged()事件時(shí),當(dāng)改變checkbox狀態(tài)時(shí),只有當(dāng)焦點(diǎn)離開(kāi)該單元格時(shí)才能觸發(fā)CellValueChanged()事件,

如果要改變checkbox值時(shí)實(shí)時(shí)觸發(fā)CellValueChanged()事件,需要借用CurrentCellDirtyStateChanged()事件來(lái)提交未提交控件的更改。

private void dataGridView1_CurrentCellDirtyStateChanged(object sender, EventArgs e)
  {
   if (dataGridView1.IsCurrentCellDirty)
   {
    dataGridView1.CommitEdit(DataGridViewDataErrorContexts.Commit);
   }
  }

事實(shí)上,當(dāng)調(diào)用dataGridView1.CommitEdit(DataGridViewDataErrorContexts.Commit);時(shí),就提交了當(dāng)前的修改,很多其它事件都會(huì)有響應(yīng),其中CellValueChanged就是其中之一。
這樣CellValueChanged()事件就可以隨著checkbox的值的改變實(shí)時(shí)觸發(fā)。
以全選/反選為例說(shuō)明當(dāng)DataGridViewCheckBoxColumn發(fā)生變化時(shí)怎么處理全選/反選。
CheckBox有3種狀態(tài):選中(CheckState.Checked)/取消(CheckState.Unchecked)/部分選中(CheckState.Indeterminate)
在winForm組件里拖拽一個(gè)CheckBox命名為selectAllCheckBox,Text為全選,拖拽一個(gè)LinkLabel命名為revSelectLinkLbl,Text為反選。

 //全選
  private void selectAllCheckBox_CheckedChanged(object sender, EventArgs e)
  {
   CheckBox c = sender as CheckBox;
   if(c.CheckState == CheckState.Checked)
   {
    ChangeDataSourceChecked(true);
   }
   else if(c.CheckState == CheckState.Unchecked)
   {
    ChangeDataSourceChecked(false);
   }
  }

  private void ChangeDataSourceChecked(Boolean isSelected)
  {
   foreach (SavePlmBomResponseVo savePlmBomResponseVo in dataSource)
   {
    savePlmBomResponseVo.checkedC = isSelected;
   }
   dataGridView.DataSource = null;
   dataGridView.DataSource = dataSource;
  }
  /// <summary>
  /// 反選
  /// </summary>
  /// <param name="sender"></param>
  /// <param name="e"></param>
  private void revSelectLinkLbl_LinkClicked(object sender, LinkLabelLinkClickedEventArgs e)
  {
   if (this.selectAllCheckBox.CheckState == CheckState.Checked)
   {
    this.selectAllCheckBox.CheckState = CheckState.Unchecked;
   }
   else if(this.selectAllCheckBox.CheckState == CheckState.Unchecked)
   {
    this.selectAllCheckBox.CheckState = CheckState.Checked;
   }
   else
   {
    //部分選中
    foreach (SavePlmBomResponseVo savePlmBomResponseVo in dataSource)
    {
     if (savePlmBomResponseVo.checkedC)
     {
      savePlmBomResponseVo.checkedC = false;
     }
     else
     {
      savePlmBomResponseVo.checkedC = true;
     }
    }
    dataGridView.DataSource = null;
    dataGridView.DataSource = dataSource;
   }
  }

  /// <summary>
  /// 處理DataSource數(shù)據(jù)變化時(shí),全選/反選選中狀態(tài)
  /// </summary>
  private void calSelectAllCheckBoxState()
  {
   int selectedCount = 0;
   foreach (SavePlmBomResponseVo savePlmBomResponseVo in dataSource)
   {
    if (savePlmBomResponseVo.checkedC)
    {
     ++selectedCount;
    }
   }
   if (selectedCount == 0)
   {
    if(this.selectAllCheckBox.CheckState != CheckState.Unchecked)
    {
     this.selectAllCheckBox.CheckState = CheckState.Unchecked;
    }
   }
   else if (selectedCount == dataSource.Count)
   {
    if (this.selectAllCheckBox.CheckState != CheckState.Checked)
    {
     this.selectAllCheckBox.CheckState = CheckState.Checked;
    }
   }
   else
   {
    if (this.selectAllCheckBox.CheckState != CheckState.Indeterminate)
    {
     this.selectAllCheckBox.CheckState = CheckState.Indeterminate;
    }
   }
  }

  /// <summary>
  /// 提交修改狀態(tài)
  /// </summary>
  /// <param name="sender"></param>
  /// <param name="e"></param>
  private void DataGridView_CurrentCellDirtyStateChanged(object sender, EventArgs e)
  {
   if (this.dataGridView.IsCurrentCellDirty)
   {
    this.dataGridView.CommitEdit(DataGridViewDataErrorContexts.Commit);
   }
  }

  //行值變化
  private void DataGridView_CellValueChanged(object sender, DataGridViewCellEventArgs e)
  {
   calSelectAllCheckBoxState();
  }

到此這篇關(guān)于C#開(kāi)發(fā)WinForm之DataGridView開(kāi)發(fā)詳解的文章就介紹到這了,更多相關(guān)C# DataGridView開(kāi)發(fā)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • C#結(jié)合Minio實(shí)現(xiàn)文件上傳存儲(chǔ)與更新

    C#結(jié)合Minio實(shí)現(xiàn)文件上傳存儲(chǔ)與更新

    MinIO是一個(gè)開(kāi)源的對(duì)象存儲(chǔ)服務(wù)器,專門設(shè)計(jì)用于在大規(guī)模數(shù)據(jù)存儲(chǔ)環(huán)境中運(yùn)行,這篇文章主要為大家介紹了C#如何結(jié)合Minio實(shí)現(xiàn)文件上傳存儲(chǔ)與更新,需要的可以參考下
    2024-03-03
  • Unity 按鈕添加OnClick事件操作

    Unity 按鈕添加OnClick事件操作

    這篇文章主要介紹了Unity 按鈕添加OnClick事件操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2021-04-04
  • C# 計(jì)算傳入的時(shí)間距離今天的時(shí)間差

    C# 計(jì)算傳入的時(shí)間距離今天的時(shí)間差

    本文通過(guò)一段簡(jiǎn)單的代碼給大家介紹了C# 計(jì)算傳入的時(shí)間距離今天的時(shí)間差,代碼簡(jiǎn)單易懂,需要的朋友參考下吧
    2017-08-08
  • Windows系統(tǒng)中使用C#編寫(xiě)藍(lán)牙通信程序的簡(jiǎn)單實(shí)例

    Windows系統(tǒng)中使用C#編寫(xiě)藍(lán)牙通信程序的簡(jiǎn)單實(shí)例

    這篇文章主要介紹了Windows系統(tǒng)中使用C#編寫(xiě)藍(lán)牙通信程序的簡(jiǎn)單實(shí)例,文中的例子使用到了32feet.NET中的InTheHand.Net.Personal類庫(kù),需要的朋友可以參考下
    2016-04-04
  • WinForm項(xiàng)目開(kāi)發(fā)中Excel用法實(shí)例解析

    WinForm項(xiàng)目開(kāi)發(fā)中Excel用法實(shí)例解析

    這篇文章主要介紹了WinForm項(xiàng)目開(kāi)發(fā)中Excel用法,非常實(shí)用,需要的朋友可以參考下
    2014-08-08
  • C#中設(shè)計(jì)、使用Fluent API

    C#中設(shè)計(jì)、使用Fluent API

    這篇文章主要介紹了C#中設(shè)計(jì)、使用Fluent API,本文講解了最簡(jiǎn)單且最實(shí)用的設(shè)計(jì)、設(shè)計(jì)具有調(diào)用順序的Fluent API、泛型類的Fluent設(shè)計(jì)等內(nèi)容,需要的朋友可以參考下
    2015-03-03
  • C#實(shí)現(xiàn)的XML操作類實(shí)例

    C#實(shí)現(xiàn)的XML操作類實(shí)例

    這篇文章主要介紹了C#實(shí)現(xiàn)的XML操作類,涉及C#操作XML文件的讀取、插入、修改、刪除等操作技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下
    2015-08-08
  • C#對(duì)Xamarin框架進(jìn)行數(shù)據(jù)綁定

    C#對(duì)Xamarin框架進(jìn)行數(shù)據(jù)綁定

    這篇文章介紹了C#對(duì)Xamarin框架進(jìn)行數(shù)據(jù)綁定,對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2022-01-01
  • 舊項(xiàng)目升級(jí)新版Unity2021導(dǎo)致Visual?Studio無(wú)法使用的問(wèn)題

    舊項(xiàng)目升級(jí)新版Unity2021導(dǎo)致Visual?Studio無(wú)法使用的問(wèn)題

    在項(xiàng)目開(kāi)發(fā)過(guò)程中,不可避免的會(huì)升級(jí)開(kāi)發(fā)工具。這次我在舊項(xiàng)目版本升級(jí)到新版Unity2021.2.x時(shí),出現(xiàn)Visual?Studio無(wú)法定位等問(wèn)題,這里我給大家分享下解決方法,舊項(xiàng)目升級(jí)新版Unity2021導(dǎo)致Visual?Studio無(wú)法使用的問(wèn)題,需要的朋友可以參考下
    2021-12-12
  • C#實(shí)現(xiàn)猜數(shù)字小游戲

    C#實(shí)現(xiàn)猜數(shù)字小游戲

    這篇文章主要為大家詳細(xì)介紹了C#實(shí)現(xiàn)猜數(shù)字小游戲,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-03-03

最新評(píng)論