jquery實現(xiàn)一個簡單的表單驗證實例
來源:易賢網 閱讀:1076 次 日期:2016-07-14 16:16:27
溫馨提示:易賢網小編為您整理了“jquery實現(xiàn)一個簡單的表單驗證實例”,方便廣大網友查閱!

表單驗證在網站開發(fā)過程中經常遇到,我們可以使用服務器端語言驗證,也可以使用客戶端語言來驗證。本文章向大家介紹jquery客戶端驗證表單的一個簡單實例。實例僅作參考。

<body>

<form method="post" action="">

  <div class="int">

    <label for="username">用戶名:</label>

    <!-- 為每個需要的元素添加required -->

    <input type="text" id="username" class="required" />

  </div>

  <div class="int">

    <label for="email">郵箱:</label>

    <input type="text" id="email" class="required" />

  </div>

  <div class="int">

    <label for="personinfo">個人資料:</label>

    <input type="text" id="personinfo" />

  </div>

  <div class="sub">

    <input type="submit" value="提交" id="send"/><input type="reset" id="res"/>

  </div>

</form>

</body>

<script src="/Public/js/jquery-1.7.1.min.js"></script>

<script type="text/javascript">

//<![CDATA[

$(function(){

    /*

    *思路大概是先為每一個required添加必填的標記,用each()方法來實現(xiàn)。

    *在each()方法中先是創(chuàng)建一個元素。然后通過append()方法將創(chuàng)建的元素加入到父元素后面。

    *這里面的this用的很精髓,每一次的this都對應著相應的input元素,然后獲取相應的父元素。

    *然后為input元素添加失去焦點事件。然后進行用戶名、郵件的驗證。

    *這里用了一個判斷is(),如果是用戶名,做相應的處理,如果是郵件做相應的驗證。

    *在jQuery框架中,也可以適當?shù)拇┎逡粚懺兜膉avascript代碼。比如驗證用戶名中就有this.value,和this.value.length。對內容進行判斷。

    *然后進行的是郵件的驗證,貌似用到了正則表達式。

    *然后為input元素添加keyup事件與focus事件。就是在keyup時也要做一下驗證,調用blur事件就行了。用triggerHandler()觸發(fā)器,觸發(fā)相應的事件。

    *最后提交表單時做統(tǒng)一驗證

    *做好整體與細節(jié)的處理

    */

    //如果是必填的,則加紅星標識.

    $("form :input.required").each(function(){

      var $required = $("<strong class='high'> *</strong>"); //創(chuàng)建元素

      $(this).parent().append($required); //然后將它追加到文檔中

    });

     //文本框失去焦點后

    $('form :input').blur(function(){

       var $parent = $(this).parent();

       $parent.find(".formtips").remove();

       //驗證用戶名

       if( $(this).is('#username') ){

          if( this.value=="" || this.value.length < 6 ){

            var errorMsg = '請輸入至少6位的用戶名.';

            $parent.append('<span class="formtips onError">'+errorMsg+'</span>');

          }else{

            var okMsg = '輸入正確.';

            $parent.append('<span class="formtips onSuccess">'+okMsg+'</span>');

          }

       }

       //驗證郵件

       if( $(this).is('#email') ){

        if( this.value=="" || ( this.value!="" && !/.+@.+\.[a-zA-Z]{2,4}$/.test(this.value) ) ){

           var errorMsg = '請輸入正確的E-Mail地址.';

           $parent.append('<span class="formtips onError">'+errorMsg+'</span>');

        }else{

           var okMsg = '輸入正確.';

           $parent.append('<span class="formtips onSuccess">'+okMsg+'</span>');

        }

       }

    }).keyup(function(){

      $(this).triggerHandler("blur");

    }).focus(function(){

       $(this).triggerHandler("blur");

    });//end blur

    //提交,最終驗證。

     $('#send').click(function(){

        $("form :input.required").trigger('blur');

        var numError = $('form .onError').length;

        if(numError){

          return false;

        } 

        alert("注冊成功,密碼已發(fā)到你的郵箱,請查收.");

     });

    //重置

     $('#res').click(function(){

        $(".formtips").remove(); 

     });

})

//]]>

</script>

以上這篇jquery實現(xiàn)一個簡單的表單驗證實例就是小編分享給大家的全部內容了,希望能給大家一個參考

更多信息請查看網絡編程

2025國考·省考課程試聽報名

  • 報班類型
  • 姓名
  • 手機號
  • 驗證碼
關于我們 | 聯(lián)系我們 | 人才招聘 | 網站聲明 | 網站幫助 | 非正式的簡要咨詢 | 簡要咨詢須知 | 新媒體/短視頻平臺 | 手機站點 | 投訴建議
工業(yè)和信息化部備案號:滇ICP備2023014141號-1 云南省教育廳備案號:云教ICP備0901021 滇公網安備53010202001879號 人力資源服務許可證:(云)人服證字(2023)第0102001523號
聯(lián)系電話:0871-65099533/13759567129 獲取招聘考試信息及咨詢關注公眾號:hfpxwx
咨詢QQ:1093837350(9:00—18:00)版權所有:易賢網