本篇文章給大家分享的是有關怎么在C#中利用WinForm對DataGridView進行開發(fā),小編覺得挺實用的,因此分享給大家學習,希望大家閱讀完這篇文章后可以有所收獲,話不多說,跟著小編一起來看看吧。
為雜多等地區(qū)用戶提供了全套網頁設計制作服務,及雜多網站建設行業(yè)解決方案。主營業(yè)務為成都網站制作、網站建設、雜多網站設計,以傳統(tǒng)方式定制建設網站,并提供域名空間備案等一條龍服務,秉承以專業(yè)、用心的態(tài)度為用戶提供真誠的服務。我們深信只要達到每一位用戶的要求,就會得到認可,從而選擇與我們長期合作。這樣,我們也可以走得更遠!根據提供的數據展示出效果。
提供給DataGridView數據源有很多方式,大致有如下三種:
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";
直接增加一行,在行上的每天單元格內添加數據,缺點是太單一
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);
可選的類型如下圖:
上面2種都不是我想要的,因為列表展示的數據大部分情況下是復雜的后臺回傳的數據。所以我建議使用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; } }
構造一個List,將InfoVo放進List對象里,然后將List對象賦值給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自動根據vo屬性創(chuàng)建列。
在窗體上選中DataGridView,在屬性面板里點擊Columns選項。如下圖
在打開的面板里,我們可以創(chuàng)建列。選擇是否可見,設置抬頭
DataPropertyName:指定列綁定的數據源屬性字段。
在DolumnType里我們可以指定單元格類型,如下圖
比如下拉框,或者單元框。
至此,我們可以渲染出DataGridView組件里,下面看一些屬性。
foreach (DataGridViewColumn column in dataGridView.Columns) { column.AutoSizeMode = DataGridViewAutoSizeColumnMode.AllCells; }
成員名稱 | 說明 |
---|---|
NotSet | 列的大小調整行為從DataGridView.AutoSizeColumnsMode 屬性繼承。 |
None | 列寬不會自動調整。 |
AllCells | 調整列寬,以適合該列中的所有單元格的內容,包括標題單元格。 |
AllCellsExceptHeader | 調整列寬,以適合該列中的所有單元格的內容,不包括標題單元格。 |
DisplayedCells | 調整列寬,以適合當前屏幕上顯示的行的列中的所有單元格的內容,包括標題單元格。 |
DisplayedCellsExceptHeader | 調整列寬,以適合當前屏幕上顯示的行的列中的所有單元格的內容,不包括標題單元格。 |
ColumnHeader | 調整列寬,以適合列標題單元格的內容。 |
Fill | 調整列寬,使所有列的寬度正好填充控件的顯示區(qū)域,只需要水平滾動保證列寬在DataGridViewColumn.MinimumWidth屬性值以上。相對列寬由相對DataGridViewColumn.FillWeight屬性值決定。 |
如果想讓列寬能按比例填充顯示區(qū)域則column.AutoSizeMode = DataGridViewAutoSizeColumnMode.Fill;
2個屬性
AllowUserToResizeColumns:true:禁止縮放列
AllowUserToResizeRows:true:禁止縮放行
用戶可以拖動的方式排序列展示
AllowUserToOrderColumns:true
窗體的ReadOnly為false
在Columns彈出的列編輯窗口里,選擇列的ReadOnly為false
SelectionMode為RowReadSelect(這是默認值)
在屬性面板里選中RowheadersVisible和ColumnHeadersVisible,置為false
將RowheadersVisible置為false即可。
為RowStateChanged事件添加監(jiān)聽,(在屬性面板右邊閃電圖標下找)。
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(); }
行號沒有完全顯示出來的解決辦法是將DataGridView的RowHeadersWidthSizeMode屬性設置為AutoSizeToAllHeaders、AutoSizeToDisplayedHeaders或者AutoSizeToFirstHeader。
如果我們提供的vo對象,dataGrid會自動根據屬性創(chuàng)建列,這不是我想要的,我希望能控制顯示。如下設置即可
dataGridView.AutoGenerateColumns = false;
單元格可以顯示文件,也可以顯示單元框,下拉框,圖片和超鏈拉。只要在編輯列窗口里選擇ColumnType下拉框,選擇一下即可。當然選擇的不同,數據設置不同,比如
單選框DataGridViewCheckBoxColumn如下
下拉框DataGridViewComboBoxColumn
可以指定選中是整個行被選中還是每個小單元格被選中
SelectionMode,全部可選如下
當然還有其它,只要我們熟悉,在屬性面板上幾乎都能找到。
CellClick是選中事件,不用它即可,不要用CellContentClick
,因為如果單元格無內容,這個CellContentClick
事件不會觸發(fā)。
取得當前單元格內容 :DataGridView1.CurrentCell.Value
取得當前單元格的列 Index:DataGridView1.CurrentCell.ColumnIndex
取得當前單元格的行 Index:DataGridView1.CurrentCell.RowIndex
取得當前行:dataGridView.CurrentRow;獲得綁定的vo
:
DataGridViewRow dataGridViewRow = dataGridView.CurrentRow; InfoVo infoVo = dataGridViewRow.DataBoundItem as InfoVo ; infoVo .uidItemRevision ;
如果表格可編輯,那么編輯完表格會同步更新DataBoundItem綁定的vo對象
遍歷列表里所有單元格
foreach (DataGridViewRow item in dataGridView.Rows) { //item是每行的對象,cells是單元格集合 if (null != item.Cells[0].Value && (Boolean)item.Cells[0].Value) { item.Cells[0].Value.toString(); } }
使用 DataGridView.CurrentCellAddress 屬性(而不是直接訪問單元格)來確定單元格所在的
行: DataGridView.CurrentCellAddress.Y
列: DataGridView.CurrentCellAddress.X 。
當前的單元格可以通過設定 DataGridView 對象的 CurrentCell 來改變??梢酝ㄟ^ CurrentCell 來設定
DataGridView 的激活單元格。將 CurrentCell 設為 Nothing(null) 可以取消激活的單元格。
正常響應CellValueChanged()事件時,當改變checkbox狀態(tài)時,只有當焦點離開該單元格時才能觸發(fā)CellValueChanged()事件,
如果要改變checkbox值時實時觸發(fā)CellValueChanged()事件,需要借用CurrentCellDirtyStateChanged()事件來提交未提交控件的更改。
private void dataGridView1_CurrentCellDirtyStateChanged(object sender, EventArgs e) { if (dataGridView1.IsCurrentCellDirty) { dataGridView1.CommitEdit(DataGridViewDataErrorContexts.Commit); } }
事實上,當調用dataGridView1.CommitEdit(DataGridViewDataErrorContexts.Commit);時,就提交了當前的修改,很多其它事件都會有響應,其中CellValueChanged就是其中之一。
這樣CellValueChanged()事件就可以隨著checkbox的值的改變實時觸發(fā)。
以全選/反選為例說明當DataGridViewCheckBoxColumn發(fā)生變化時怎么處理全選/反選。
CheckBox有3種狀態(tài):選中(CheckState.Checked)/取消(CheckState.Unchecked)/部分選中(CheckState.Indeterminate)
在winForm組件里拖拽一個CheckBox命名為selectAllCheckBox,Text為全選,拖拽一個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數據變化時,全選/反選選中狀態(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(); }
以上就是怎么在C#中利用WinForm對DataGridView進行開發(fā),小編相信有部分知識點可能是我們日常工作會見到或用到的。希望你能通過這篇文章學到更多知識。更多詳情敬請關注創(chuàng)新互聯行業(yè)資訊頻道。
文章標題:怎么在C#中利用WinForm對DataGridView進行開發(fā)-創(chuàng)新互聯
鏈接分享:http://jinyejixie.com/article18/coigdp.html
成都網站建設公司_創(chuàng)新互聯,為您提供外貿建站、商城網站、做網站、網站改版、域名注冊、網站內鏈
聲明:本網站發(fā)布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創(chuàng)新互聯