主頁 > 知識庫 > 在ASP.NET 2.0中操作數(shù)據(jù)之三十九:在DataList的編輯界面里添加驗(yàn)證控件

在ASP.NET 2.0中操作數(shù)據(jù)之三十九:在DataList的編輯界面里添加驗(yàn)證控件

熱門標(biāo)簽:臨沂智能電話機(jī)器人加盟 地圖標(biāo)注軟件免費(fèi)下載 網(wǎng)絡(luò)電話外呼系統(tǒng)上海 百應(yīng)電話機(jī)器人外呼系統(tǒng) 蘇州如何辦理400電話 西寧呼叫中心外呼系統(tǒng)線路商 400電話辦理怎么樣 外呼電話機(jī)器人成本 聯(lián)通官網(wǎng)400電話辦理

導(dǎo)言

  到目前為止的討論編輯DataList的教程里,沒有包含任何驗(yàn)證用戶的輸入,即使是用戶非法輸入— 遺漏了product的name或者負(fù)的price— 會導(dǎo)致異常。在前面一章里我們學(xué)習(xí)了如何在DataList的UpdateCommand事件處理中添加異常處理代碼,以便在出現(xiàn)異常時捕捉它并顯示友好的錯誤信息。然而理想的編輯界面應(yīng)該包含驗(yàn)證控件,用來在第一時間里阻止用戶輸入一些非法數(shù)據(jù)。

  本章我們將學(xué)習(xí)在DataList的EditItemTemplate里添加驗(yàn)證控件從而提供一個更安全的編輯界面,這非常容易。本章將使用前面創(chuàng)建的例子,并擴(kuò)展編輯界面用來添加合適的驗(yàn)證控件。

第一步: 從 處理 BLL和 DAL的異常復(fù)制例子

  在處理BLL和DAL的異常里我們創(chuàng)建了一個以兩列的方式列出product的name和price的DataList。本章的目標(biāo)是擴(kuò)展這個DataList的編輯界面,讓它包含驗(yàn)證控件。我們的驗(yàn)證邏輯如下:

product的 name 是必填的
確保輸入的price的值是合法的貨幣類型格式
確保輸入的price的值大于等于0

  我們首先需要將ErrorHandling.aspx頁的例子復(fù)制到UIValidation.aspx里。這其中包括頁面的聲明代碼和后臺代碼。下面是復(fù)制聲明代碼的步驟:

  在Visual Studio的打開 ErrorHandling.aspx 切換到源視圖 復(fù)制從 asp:Content> 到/asp:Content> 標(biāo)簽內(nèi)的代碼, 見圖1.


圖 1: 復(fù)制asp:Content> 內(nèi)的代碼

  打開UIValidation.aspx 切換到源視圖 ,粘貼代碼.

  完成上面的步驟后,打開ErrorHandling.asxp.cs,復(fù)制DispalyExcetionDetails方法和三個事件處理(Products_EditCommand,Products_CancelCommand, 和Products_UpdateCommand),注意不要復(fù)制聲明類和using的代碼。將這些代碼粘貼到ErrorHandling.asxp.cs里的EditDeleteDataList_UIValidation 類里。完成這些后,瀏覽一下頁面。這兩個頁面無論是輸出還是功能都是一樣的(見圖2)。


圖 2: UIValidation.aspx 頁ErrorHandling.aspx一樣

第二步: 為DataList的 EditItemTemplate添加驗(yàn)證控件

  當(dāng)創(chuàng)建輸入表格時,很重要的一點(diǎn)是聲明必填字段和用戶的輸入必須是格式正確的合法值。為了確保用戶輸入是合法的,ASP.NET提供了5個內(nèi)置的驗(yàn)證控件,這些驗(yàn)證控件被設(shè)計(jì)用來驗(yàn)證單個的輸入控件里的輸入值。

RequiredFieldValidator —確保必填值
CompareValidator — 根據(jù)另外的控件的值或常量來驗(yàn)證某個值,或者確保輸入值是特定的類型
RangeValidator — 確保輸入值在某個范圍內(nèi)
RegularExpressionValidator — 根據(jù)正則表達(dá)式( regular expression )來驗(yàn)證某個值
CustomValidator — 根據(jù)用戶自定義的方法來驗(yàn)證某個值

  更多的關(guān)于這5個控件的信息請參考給編輯和新增界面增加驗(yàn)證控件  或著ASP.NET Quickstart Tutorials里的Validation Controls section。

  本章里我們需要使用RequiredFieldValidator 來確保用戶輸入了product的name,CompareValidator 來確保price的值大于等于0并且是合法的貨幣格式。

  注意:在ASP.NET 1.x里已經(jīng)包含了這些驗(yàn)證控件了,在ASP.NET 2.0里對它們有很多改進(jìn)。其中最重要的兩點(diǎn)一是對除了IE之外的瀏覽器的客戶端腳本支持,二是同一頁面上的驗(yàn)證控件分組。更多的2.0里驗(yàn)證控件新特性的信息請參考Dissecting the Validation Controls in ASP.NET 2.0.

  現(xiàn)在我們來將需要的驗(yàn)證控件添加到DataList的EditItemTemplate里。這個可以通過點(diǎn)擊DataList智能標(biāo)簽上的Edit Template,或者直接寫聲明代碼來完成。我們這里使用第一種方法。選擇Edit Template后拖一個RequiredFieldValidator 進(jìn)來,將它放在ProductName TextBox后面。


圖 3: 添加 RequiredFieldValidator

  所有的驗(yàn)證控件都只驗(yàn)證單個的Web控件。因此我們需要指明剛添加的RequiredFieldValidator 是用來驗(yàn)證ProductName TextBox。這個關(guān)聯(lián)是通過將驗(yàn)證控件的ControlToValidate property設(shè)為合適的Web控件(在這里是ProductName).然后將ErrorMessage property設(shè)為“You must provide the product's name”,Text property設(shè)為“*”。如果提供了Text屬性的值,它將在驗(yàn)證失敗時顯示。ErrorMessage 屬性是提供給ValidationSummary 控件使用的。如果省略了Text的值,在非法輸入時會顯示 ErrorMessage 。完成這些后你的頁面看起來應(yīng)該和圖4差不多:


圖 4: 設(shè)置 RequiredFieldValidator的 ControlToValidate, ErrorMessage, 和Text Properties

  添加完RequiredFieldValidator 后,剩下的事就是為product的price添加驗(yàn)證控件了。由于編輯時UnitPrice屬于可選項(xiàng),所以我們不用添加RequiredFieldValidator。我們需要做的是添加一個CompareValidator 來保證在輸入了price的情況下,它的值是正確的貨幣格式和大于等于0。

  為EditIteTemplate添加一個ControlToValidate 屬性為UnitPrice的CompareValidator 。將ErrorMessage 設(shè)為“The price must be greater than or equal to zero and cannot include the currency symbol”,Text設(shè)為“*”。為了指定UnitPrice的值必須大于等于0,將CompareValidator的Operator property設(shè)為GreaterThanEqual,ValueToCompare property設(shè)為“0”,Type property設(shè)為Currency。添加完這兩個驗(yàn)證控件后,DataList的EditItemTemplate聲明代碼應(yīng)該和下面差不多:

EditItemTemplate>
 Product name:
 asp:TextBox ID="ProductName" runat="server"
  Text='%# Eval("ProductName") %>'>/asp:TextBox>
 asp:RequiredFieldValidator ID="RequiredFieldValidator1"
  ControlToValidate="ProductName"
  ErrorMessage="You must provide the product's name"
  runat="server">*/asp:RequiredFieldValidator>
 br />
 Price:
 asp:TextBox ID="UnitPrice" runat="server"
  Text='%# Eval("UnitPrice", "{0:C}") %>'>/asp:TextBox>
 asp:CompareValidator ID="CompareValidator1"
  ControlToValidate="UnitPrice"
  ErrorMessage="The price must be greater than or equal to zero
    and cannot include the currency symbol"
  Operator="GreaterThanEqual" Type="Currency" ValueToCompare="0"
  runat="server">*/asp:CompareValidator>br />
 br />
 asp:Button ID="UpdateProduct" runat="server" CommandName="Update"
 Text="Update" /> 
 asp:Button ID="CancelUpdate" runat="server" CommandName="Cancel"
 Text="Cancel" />
/EditItemTemplate>

  瀏覽一下頁面?,F(xiàn)在如果你編輯的時候不輸入name或者在price里輸入一個非法的值,在textbox后面會出現(xiàn)一個“*”。見圖5。一個包含貨幣符號的值—比如$19.95 —被認(rèn)為是合法的。CompareValidator的Currency 類型允許數(shù)字分隔符(比如句號和逗號)和前面帶"+"或"-"號,但是不允許帶貨幣符號。而在編輯界面里的UnitPrice又會以貨幣格式展現(xiàn),這可能會讓用戶感到困惑。


圖 5: 非法輸入 Textboxes 后面會出現(xiàn)“*”

  當(dāng)驗(yàn)證控件象上面這樣工作時,用戶在編輯時需要手工移除掉貨幣符號,這是不可接受的。而且,如果在編輯的時候有非法輸入,不管是點(diǎn)Update還是Cancel button,頁面都會postback。理想的情況是,點(diǎn)Cancel button會返回DataList的編輯前狀態(tài),而不管輸入的值是否合法。當(dāng)然由于用戶的瀏覽器可能不支持JavaScript 或者被禁用了,在更新product信息前我們要在UpdateCommand事件處理里確保頁面的數(shù)據(jù)都是合法的。

  從EditItemTemplate的UnitPrice TextBox里移除貨幣符號

  當(dāng)使用CompareValidator的貨幣類型時,輸入不能包含任何貨幣符號,否則CompareValidator 會視為非法。然而編輯界面里的UnitPrice TextBox已經(jīng)包含了一個貨幣符號,這就意味著用戶在保存前必須手動移除它。我們有三種方法來修補(bǔ)它:

  配置EditItemTemplate 使 UnitPrice TextBox 的值的格式不為貨幣. 用RegularExpressionValidator 代替CompareValidator來檢查正確格式的貨幣值 . 這里的挑戰(zhàn)是用正則表達(dá)式不象用CompareValidator 那樣直接,方便,需要寫一些代碼。 移除所有的驗(yàn)證控件,驗(yàn)證的功能將完全依賴于服務(wù)器端的GridView的RowUpdating事件處理。

  我們這里使用第一種方法?,F(xiàn)在UnitPrice為貨幣格式是由于TextBox的綁定表達(dá)式%# Eval("UnitPrice", "{0:c}") %>. 將它修改為 Eval("UnitPrice", "{0:n2}")(允許兩位小數(shù)的數(shù)字)。這個可以通過點(diǎn)擊DataList里EditItemTemplate里的UnitPrice TextBox的Edit DataBindings鏈接或直接修改聲明語法來完成。完成這些后,編輯界面的price格式包含兩種分隔符,逗號和句號。

  注意:在移除貨幣格式的時候,我發(fā)現(xiàn)將貨幣符號作為text放在TextBox前面是一種好的做法。它會提醒用戶他們不需要再輸入貨幣符號。

修補(bǔ) Cancel Button

  默認(rèn)情況下,驗(yàn)證控件生成JavaScript 在客戶端執(zhí)行驗(yàn)證。當(dāng)點(diǎn)擊Button, LinkButton, 或ImageButton時,驗(yàn)證控件會在頁面postback之前檢查。如果有非法的數(shù)據(jù),postback不會發(fā)生。然而對某些Button來說,這時并不需要驗(yàn)證數(shù)據(jù)。在這樣的情況下,取消了postback是非常討厭的。

  Cancel button就屬于這種情況。想象一下用戶輸入了非法的數(shù)據(jù),比如忽略了product的name,然后決定他不需要保存product,然后點(diǎn)擊了Cancel button。在這種情況下,Cancel button會觸發(fā)驗(yàn)證控件,它會報告說缺少product的name,并阻止postback。我們的用戶不得不向Product TextBox里輸入一些文字然后再取消編輯。

  幸運(yùn)的是,Button, LinkButton, 和ImageButton 有CausesValidation property,它可以指明當(dāng)點(diǎn)擊Button時是否需要發(fā)起驗(yàn)證(默認(rèn)為True)。將 Cancel Button的CausesValidation 設(shè)為False.

  在 UpdateCommand Event Handler里確保輸入是合法的

  客戶端的腳本是由驗(yàn)證控件生成的,如果用戶輸入非法數(shù)據(jù),并點(diǎn)擊CausesValidation屬性 為True的button時將不會引起postback。然而如果用戶用戶使用的是版本很低的瀏覽器或者禁用了對JavaScript 的支持,那么客戶端的驗(yàn)證將不會執(zhí)行。

  頁面postback的時候所有的驗(yàn)證控件執(zhí)行驗(yàn)證,然后將驗(yàn)證報告提交給Page.IsValid property。然而,整個流程并不會被Page.IsValid的值打斷。作為開發(fā)者,我們需要保證在Page.IsValid為True的情況下代碼再繼續(xù)運(yùn)行。

  如果禁用了JavaScript 的用戶瀏覽我們的頁,編輯了product,在price里輸入一個“太貴”的值,然后點(diǎn)Update button,客戶端的驗(yàn)證將被跳過,頁面會繼續(xù)postback。UpdateCommand事件處理將執(zhí)行,隨后在試圖將“太貴”的價格轉(zhuǎn)換為Decimal時拋出異常。雖然已經(jīng)寫過異常處理了,但是我們其實(shí)可以根據(jù)Page.IsValid的值在第一時間里阻止非法輸入。

在UpdateCommand 的最開始加上下面的代碼:

if (!Page.IsValid)
 return;

  完成這個后,product將只在提交的數(shù)據(jù)合法時才被更新。大多數(shù)用戶的非法提交會由于客戶端腳本而被拒絕postback,而那些瀏覽器不支持JavaScript 或禁用了JavaScript 的客戶會跳過客戶端檢查,提交非法數(shù)據(jù)。

  注意:細(xì)心的讀者會記起在GridView里更新數(shù)據(jù)時,我們并不需要顯式的檢查Page.IsValid 。這是因?yàn)镚ridView已經(jīng)幫我們完成了這部分工作,即它只在Page.IsValid 為True時才繼續(xù)更新。

第三步: Summarizing Data Entry Problems

  除了上面提到的5種驗(yàn)證控件外,ASP.NET還包含ValidationSummary control,它用來顯示那些檢查到非法數(shù)據(jù)的驗(yàn)證控件的錯誤信息。這些匯總的數(shù)據(jù)可以以文本或客戶端消息框的方式顯示。我們現(xiàn)在來添加包含驗(yàn)證問題匯總信息的客戶端消息框。

  拖一個ValidationSummary 進(jìn)來。由于我們將它配置為以消息框的形式顯示匯總信息,所以它的位置無所謂。將 ShowSummary property設(shè)為False, ShowMessageBox property設(shè)為True.這樣,所有驗(yàn)證的錯誤信息會以客戶端消息框的形式顯示。見圖6。


圖 6: 用一個客戶端消息框匯總驗(yàn)證的錯誤信息

總結(jié)

  本章我們學(xué)習(xí)了如何使用驗(yàn)證控件保證在更新開始前確保用戶的輸入是合法的,從而減少異常的出現(xiàn)。ASP.NET提供了5種驗(yàn)證控件來檢查特定的控件的輸入并報告是否合法。本章我們使用了其中的兩種 —RequiredFieldValidator  和CompareValidator —來保證product的name是必填的和price是大于等于0的貨幣格式。

  在DataList的編輯界面里加驗(yàn)證控件只需要簡單的將它們拖到EditItemTemplate里,然后設(shè)置幾個屬性。默認(rèn)情況下驗(yàn)證控件自動生成客戶端驗(yàn)證腳本,當(dāng)然也提供在postback時的服務(wù)器端驗(yàn)證,并將所有的結(jié)果累積保存在Page.IsValid 里。在點(diǎn)擊Button,LinkButton或ImageButton時,可以將CausesValidation 設(shè)為False從而跳過客戶端驗(yàn)證。在執(zhí)行任何代碼前,首先需要保證 Page.IsValid 為True.

  目前我們學(xué)習(xí)的DataList的編輯教程都只是簡單的界面— 在TextBox里顯示name和price。然而編輯界面可以包含各種不同的web控件,比如DropDownLists,Calenda,RadioButtons, CheckBoxes等。我們下章會創(chuàng)建一個包含各種web控件的界面。

  祝編程快樂!

作者簡介

  本系列教程作者 Scott Mitchell,著有六本ASP/ASP.NET方面的書,是4GuysFromRolla.com的創(chuàng)始人,自1998年以來一直應(yīng)用 微軟Web技術(shù)。大家可以點(diǎn)擊查看全部教程《[翻譯]Scott Mitchell 的ASP.NET 2.0數(shù)據(jù)教程》,希望對大家的學(xué)習(xí)ASP.NET有所幫助。

您可能感興趣的文章:
  • ASP.NET2.0數(shù)據(jù)庫入門之SqlDataSource
  • SqlDataSource 鏈接Access 數(shù)據(jù)
  • aspx中的mysql操作類sqldatasource使用示例分享
  • 在ASP.NET 2.0中操作數(shù)據(jù)之四十:自定義DataList編輯界面
  • 在ASP.NET 2.0中操作數(shù)據(jù)之四十一:DataList和Repeater數(shù)據(jù)分頁
  • 在ASP.NET 2.0中操作數(shù)據(jù)之四十二:DataList和Repeater數(shù)據(jù)排序(一)
  • 在ASP.NET 2.0中操作數(shù)據(jù)之四十三:DataList和Repeater數(shù)據(jù)排序(二)
  • 在ASP.NET 2.0中操作數(shù)據(jù)之四十四:DataList和Repeater數(shù)據(jù)排序(三)
  • 在ASP.NET 2.0中操作數(shù)據(jù)之四十五:DataList和Repeater里的自定義Button
  • 在ASP.NET 2.0中操作數(shù)據(jù)之四十六:使用SqlDataSource控件檢索數(shù)據(jù)
  • 在ASP.NET 2.0中操作數(shù)據(jù)之四十七:用SqlDataSource控件插入、更新、刪除數(shù)據(jù)

標(biāo)簽:聊城 清遠(yuǎn) 甘肅 臨夏 中衛(wèi) 慶陽 海西 巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《在ASP.NET 2.0中操作數(shù)據(jù)之三十九:在DataList的編輯界面里添加驗(yàn)證控件》,本文關(guān)鍵詞  在,ASP.NET,2.0,中,操作,數(shù)據(jù),;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。

  • 相關(guān)文章
  • 下面列出與本文章《在ASP.NET 2.0中操作數(shù)據(jù)之三十九:在DataList的編輯界面里添加驗(yàn)證控件》相關(guān)的同類信息!
  • 本頁收集關(guān)于在ASP.NET 2.0中操作數(shù)據(jù)之三十九:在DataList的編輯界面里添加驗(yàn)證控件的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章