摘要
一般執行新增/修改完畢准備異動數據庫前通常會做一層數據正確性檢查的動作當我們使用 GridView 系結 SqlDataSoruce 來呈現數據若 GridView 進行數據編輯存盤前也要做字段值的檢查應該在如何做呢應該在那個控件的那個事件去處理這個檢查動作呢
程序說明及實作
首先在頁面上放置一個 GridView 及 SqlDataSource 控件GridView 設為可編輯狀態
data:image/s3,"s3://crabby-images/46c6e/46c6edbca3ad5a085d8c8c0de39445fcb65408bf" alt=""
data:image/s3,"s3://crabby-images/4f20b/4f20b12bd7cd97a78ab0902fb7badeb2eac7e19e" alt=""
當 GridView 編輯儲存時我們要先做一些字段值正確性的檢查動作以下的范例為測試示范只判斷 LastName 字段不得為空這種必填字段的判斷一般只要使用 RequiredFieldValidator 控件在 Client 端即可
方法一在 GridView 的 RowUpdating 事件處理字段檢查
GridView 在編輯儲存前會引發 RowUpdating 事件我們可以在此事件中處理字段檢查字段檢查的程序代碼如下當字段檢查不合法時設定 eCancel = True 即可中斷數據更新的動作執行程序故意將 LastName 清空然後按 [更新] 鈕進行儲存字段檢查的動作就被執行了
data:image/s3,"s3://crabby-images/140ad/140ad9e7168a2699720ba83a24816e98679238c5" alt=""
方法二在 SqlDataSource 的 Updating 事件處理字段檢查
對於 SqlDataSource 來說編輯數據異動數據庫之前會引發 SqlDataSource 的 Updating 事件
字段檢查的程序代碼如下當字段檢查不合法時設定 eCancel = True 即可中斷數據更新的動作這種方式的執行結果跟上個作法一樣
data:image/s3,"s3://crabby-images/0f8c8/0f8c83b7ab8ca51aab99adbd4ea8ed761145379d" alt=""
data:image/s3,"s3://crabby-images/9bdc6/9bdc6ee77baf493d86415eb3acf490881b9b7d6b" alt=""
Protected Sub GridView
_RowUpdating()Sub GridView
_RowUpdating(ByVal sender As Object
ByVal e As System
Web
UI
WebControls
GridViewUpdateEventArgs) Handles GridView
RowUpdating
data:image/s3,"s3://crabby-images/3ac09/3ac099203c7ce73560830a5046e73ed57919de67" alt=""
Dim sScript As String
data:image/s3,"s3://crabby-images/3ac09/3ac099203c7ce73560830a5046e73ed57919de67" alt=""
data:image/s3,"s3://crabby-images/3ac09/3ac099203c7ce73560830a5046e73ed57919de67" alt=""
If String
IsNullOrEmpty(e
NewValues
Item(
LastName
)) Then
data:image/s3,"s3://crabby-images/3ac09/3ac099203c7ce73560830a5046e73ed57919de67" alt=""
sScript =
alert(
LastName 欄位不得為空
)
data:image/s3,"s3://crabby-images/3ac09/3ac099203c7ce73560830a5046e73ed57919de67" alt=""
Me
ClientScript
RegisterStartupScript(Me
GetType
error
sScript
True)
data:image/s3,"s3://crabby-images/3ac09/3ac099203c7ce73560830a5046e73ed57919de67" alt=""
e
Cancel = True
data:image/s3,"s3://crabby-images/3ac09/3ac099203c7ce73560830a5046e73ed57919de67" alt=""
End If
data:image/s3,"s3://crabby-images/749d2/749d209348d7ab5503282592e2d4d4d90026de47" alt=""
End Sub
From:http://tw.wingwit.com/Article/program/net/201311/13964.html