小男孩‘自慰网亚洲一区二区,亚洲一级在线播放毛片,亚洲中文字幕av每天更新,黄aⅴ永久免费无码,91成人午夜在线精品,色网站免费在线观看,亚洲欧洲wwwww在线观看

分享

.Net驗證控件與自定義驗證合作無間

 青格兒 2011-09-02
場景:
一個注冊表單,其間有.Net自帶的驗證控件,但有一些驗證必須得借助于另外的一些js,如驗證是否復(fù)選了注冊協(xié)議(這里為了說明,只舉這樣一個簡單的例子)。
這樣的話,會涉及到二次驗證,第一次可能是.Net驗證控件的驗證,第二次會認證用戶有沒有復(fù)選注冊協(xié)議,如何讓這二者合作無間呢?
這里不得不提到.Net的Page_ClientValidate()函數(shù),該函數(shù)返回當前Page頁中的表單有沒有通過Validate的驗證.


新建一個Page頁面,簡單的放一些控件

  1. <asp:TextBox ID="TextBox1" runat="server"></asp:TextBox>  
  2.         <asp:Button ID="Button1" runat="server"   Text="Button"    
  3.             ValidationGroup="submit" CausesValidation="True"    
  4.             onclick="Button1_Click" />  
  5.         <input type="checkbox" id="checkbox" />我已閱讀注冊協(xié)議       
  6.         <asp:RequiredFieldValidator ID="RequiredFieldValidator1" runat="server"    
  7.             ControlToValidate="TextBox1" Display="Dynamic" ErrorMessage="不能為空"    
  8.             ValidationGroup="submit"></asp:RequiredFieldValidator>  

頁面呈現(xiàn)

TextBox留空,點擊Button,會進行一次驗證,當在TextBox中輸入文本時,再點擊提交,驗證通過,引發(fā)OnClick事件,但用戶是否復(fù)選了注冊協(xié)議此處還未做判斷。

此時需要我們手寫驗證函數(shù)了
  1. <script type="text/javascript">   
  2.         function test() {   
  3.             var isCheck = document.getElementById('checkbox').checked;   
  4.             if (isCheck) {   
  5.           //Page_ClientValidate('submit'),這里有不同的ValidGroup,所以Page_ClientValidate傳遞是指定的GroupName   
  6.                 if (Page_ClientValidate('submit')) {   
  7.                     alert('驗證成功');   
  8.                     return true;   
  9.                 }   
  10.             }   
  11.             else {   
  12.                 alert('您必須同意注冊協(xié)議');   
  13.                 return false;   
  14.             }   
  15.   
  16.             return false;   
  17.         }   
  18.     </script>  

修改后的代碼
  1. <asp:TextBox ID="TextBox1" runat="server"></asp:TextBox>  
  2.        <asp:Button ID="Button1" runat="server" Text="Button" ValidationGroup="submit" CausesValidation="True"  
  3.            OnClientClick="return test();" OnClick="Button1_Click" />  
  4.        <input type="checkbox" id="checkbox" />我已閱讀注冊協(xié)議   
  5.        <asp:RequiredFieldValidator ID="RequiredFieldValidator1" runat="server" ControlToValidate="TextBox1"  
  6.            Display="Dynamic" ErrorMessage="不能為空" ValidationGroup="submit"></asp:RequiredFieldValidator>  

預(yù)覽頁面



到這里好像已經(jīng)結(jié)束了,但查看html源代碼會發(fā)現(xiàn):
  1. <input type="submit" name="Button1" value="Button"    
  2. onclick="return test();WebForm_DoPostBackWithOptions(new WebForm_PostBackOptions("Button1", "", true, "submit", "", false, false))" id="Button1" />  

Button1除了有return test()外還有WebForm_DoPostBackWithOptions這樣一段,很明顯WebForm_DoPostBackWithOptions是不會被執(zhí)行的,去掉這段也很簡單,
將Button1的CausesValidation設(shè)為false即可。

當然,你也可以完全不用驗證控件來實現(xiàn)。
 
table和js實現(xiàn)頁面居中效果  http://www./latestnews/table-he-js-shixian-page-juzhongxiaoguo/
 
===== CSS文件內(nèi)容 =====
.tbl
{
 position:absolute;
 left:expression_r((document.body.clientWidth-this.offsetWidth)/2);
 top:expression_r((document.body.clientHeight-this.offsetHeight)/2);
}
===== /CSS文件內(nèi)容 =====
注意:table的style屬性不可以在設(shè)置有值。
 
40套div+CSS經(jīng)典后臺模板.rar
 
 
 

    本站是提供個人知識管理的網(wǎng)絡(luò)存儲空間,所有內(nèi)容均由用戶發(fā)布,不代表本站觀點。請注意甄別內(nèi)容中的聯(lián)系方式、誘導(dǎo)購買等信息,謹防詐騙。如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,請點擊一鍵舉報。
    轉(zhuǎn)藏 分享 獻花(0

    0條評論

    發(fā)表

    請遵守用戶 評論公約