程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> .NET網頁編程 >> .NET實例教程 >> DataGridView 單元格驗證

DataGridView 單元格驗證

編輯:.NET實例教程
定義單元格驗證
要求:
驗證錯誤後焦點不離開。
實現:
單元格的驗證可以使用dgv_details_CellValidating事件。
驗證不通過時調用e.Cancel = true;終止事件鏈,單元格將保持編輯狀態。
調用dgv_details.CancelEdit();可以使單元格的內容會滾到修改前的值。
使用System.Windows.Forms.SendKeys.Send("^a");將全選單元格的內容。
 
單元格選中並開始編輯狀態
實現:
//DataGridVIEw獲得焦點
dgv_details.Focus();
//DataGridVIEw指定當前單元格
dgv_details.CurrentCell = dgv_details[0, 0];
//開始編輯狀態
dgv_details.BeginEdit(false);
 
定制自動生成綁定了列
實現:
dgv_details.AutoGenerateColumns = false;
 
設置列的背景色
實現:
Color GridReadOnlyColor = Color.LightGoldenrodYellow;
dgv_details.Columns[1].DefaultCellStyle.BackColor =
WinKeys.GridReadOnlyColor;
 
DataGridVIEw單元格驗證的設計的問題
問題一:綁定還是不綁定?
綁定的優勢:比較簡單,代碼少。
綁定得缺點:DataGridVIEw中的數據受數據源的影響(主鍵約束、值類型約束)。不一至時會激發DataError事件,輸入的內容無法保存到單元格中和數據源中。特殊的驗證(比如長度、格式等)還是需要另外寫代碼實現。
關於增加行的問題。增加新行時多主鍵的驗證有問題,而且驗證不通過時會將新行全部刪除。限制很多,很不方便。
 
非綁定的優勢:驗證等處理比較靈活。不受數據源的約束。
非綁定得缺點:顯示和向數據庫更新數據時需要比較多的代碼實現,效率比較低。
 
總的感覺在處理驗證比較麻煩的場合,我還是比較喜歡非綁定的方式。如果數據量大,驗證比較簡單的場合使用綁定模式比較好
 

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved