DataGridView 单元格验证
生活随笔
收集整理的這篇文章主要介紹了
DataGridView 单元格验证
小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.
定義單元格驗(yàn)證
要求:
驗(yàn)證錯(cuò)誤后焦點(diǎn)不離開。
實(shí)現(xiàn):
單元格的驗(yàn)證可以使用dgv_details_CellValidating事件。
驗(yàn)證不通過時(shí)調(diào)用e.Cancel = true;終止事件鏈,單元格將保持編輯狀態(tài)。
調(diào)用dgv_details.CancelEdit();可以使單元格的內(nèi)容會(huì)滾到修改前的值。
使用System.Windows.Forms.SendKeys.Send("^a");將全選單元格的內(nèi)容。
?
單元格選中并開始編輯狀態(tài)
實(shí)現(xiàn):
//DataGridView獲得焦點(diǎn)
dgv_details.Focus();
//DataGridView指定當(dāng)前單元格
dgv_details.CurrentCell = dgv_details[0, 0];
//開始編輯狀態(tài)
dgv_details.BeginEdit(false);
?
定制自動(dòng)生成綁定了列
實(shí)現(xiàn):
dgv_details.AutoGenerateColumns = false;
?
設(shè)置列的背景色
實(shí)現(xiàn):
Color GridReadOnlyColor = Color.LightGoldenrodYellow;
dgv_details.Columns[1].DefaultCellStyle.BackColor =
WinKeys.GridReadOnlyColor;
?
DataGridView單元格驗(yàn)證的設(shè)計(jì)的問題
問題一:綁定還是不綁定?
綁定的優(yōu)勢(shì):比較簡(jiǎn)單,代碼少。
綁定得缺點(diǎn):DataGridView中的數(shù)據(jù)受數(shù)據(jù)源的影響(主鍵約束、值類型約束)。不一至?xí)r會(huì)激發(fā)DataError事件,輸入的內(nèi)容無法保存到單元格中和數(shù)據(jù)源中。特殊的驗(yàn)證(比如長(zhǎng)度、格式等)還是需要另外寫代碼實(shí)現(xiàn)。
關(guān)于增加行的問題。增加新行時(shí)多主鍵的驗(yàn)證有問題,而且驗(yàn)證不通過時(shí)會(huì)將新行全部刪除。限制很多,很不方便。
?
非綁定的優(yōu)勢(shì):驗(yàn)證等處理比較靈活。不受數(shù)據(jù)源的約束。
非綁定得缺點(diǎn):顯示和向數(shù)據(jù)庫更新數(shù)據(jù)時(shí)需要比較多的代碼實(shí)現(xiàn),效率比較低。
?
總的感覺在處理驗(yàn)證比較麻煩的場(chǎng)合,我還是比較喜歡非綁定的方式。如果數(shù)據(jù)量大,驗(yàn)證比較簡(jiǎn)單的場(chǎng)合使用綁定模式比較好?
要求:
驗(yàn)證錯(cuò)誤后焦點(diǎn)不離開。
實(shí)現(xiàn):
單元格的驗(yàn)證可以使用dgv_details_CellValidating事件。
驗(yàn)證不通過時(shí)調(diào)用e.Cancel = true;終止事件鏈,單元格將保持編輯狀態(tài)。
調(diào)用dgv_details.CancelEdit();可以使單元格的內(nèi)容會(huì)滾到修改前的值。
使用System.Windows.Forms.SendKeys.Send("^a");將全選單元格的內(nèi)容。
?
單元格選中并開始編輯狀態(tài)
實(shí)現(xiàn):
//DataGridView獲得焦點(diǎn)
dgv_details.Focus();
//DataGridView指定當(dāng)前單元格
dgv_details.CurrentCell = dgv_details[0, 0];
//開始編輯狀態(tài)
dgv_details.BeginEdit(false);
?
定制自動(dòng)生成綁定了列
實(shí)現(xiàn):
dgv_details.AutoGenerateColumns = false;
?
設(shè)置列的背景色
實(shí)現(xiàn):
Color GridReadOnlyColor = Color.LightGoldenrodYellow;
dgv_details.Columns[1].DefaultCellStyle.BackColor =
WinKeys.GridReadOnlyColor;
?
DataGridView單元格驗(yàn)證的設(shè)計(jì)的問題
問題一:綁定還是不綁定?
綁定的優(yōu)勢(shì):比較簡(jiǎn)單,代碼少。
綁定得缺點(diǎn):DataGridView中的數(shù)據(jù)受數(shù)據(jù)源的影響(主鍵約束、值類型約束)。不一至?xí)r會(huì)激發(fā)DataError事件,輸入的內(nèi)容無法保存到單元格中和數(shù)據(jù)源中。特殊的驗(yàn)證(比如長(zhǎng)度、格式等)還是需要另外寫代碼實(shí)現(xiàn)。
關(guān)于增加行的問題。增加新行時(shí)多主鍵的驗(yàn)證有問題,而且驗(yàn)證不通過時(shí)會(huì)將新行全部刪除。限制很多,很不方便。
?
非綁定的優(yōu)勢(shì):驗(yàn)證等處理比較靈活。不受數(shù)據(jù)源的約束。
非綁定得缺點(diǎn):顯示和向數(shù)據(jù)庫更新數(shù)據(jù)時(shí)需要比較多的代碼實(shí)現(xiàn),效率比較低。
?
總的感覺在處理驗(yàn)證比較麻煩的場(chǎng)合,我還是比較喜歡非綁定的方式。如果數(shù)據(jù)量大,驗(yàn)證比較簡(jiǎn)單的場(chǎng)合使用綁定模式比較好?
轉(zhuǎn)載于:https://www.cnblogs.com/weck0736/archive/2007/12/26/1015587.html
與50位技術(shù)專家面對(duì)面20年技術(shù)見證,附贈(zèng)技術(shù)全景圖總結(jié)
以上是生活随笔為你收集整理的DataGridView 单元格验证的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: (转贴) C#编码标准--编码习惯
- 下一篇: 【转】DataGridView新特色(v