DIV CSS 佈局教程網

 DIV+CSS佈局教程網 >> 網頁腳本 >> JavaScript入門知識 >> 關於JavaScript >> WEB開發之注冊頁面驗證碼倒計時代碼的實現
WEB開發之注冊頁面驗證碼倒計時代碼的實現
編輯:關於JavaScript     

近期因為開發一個新的H5+backbone 項目,驗證輸入手機號 驗證碼倒計時功能。

這裡寫圖片描述這裡寫圖片描述

#如上圖所示 要實現驗證碼的倒計時的效果

  • 首先做頁面的布局
  • 理清楚頁面效果需要實現的邏輯思路
  • 對手機號及驗證碼和密碼做正則的規則校驗

前端樣式布局代碼

<ul>
 <li class="phone bgImg">
   <input type="text" id="phone" maxlength="11" placeholder="手機號"/>
  </li>
  <li class="vCodeImg bgImg" id="sendVCode">
   <input type="text" id="smscode" maxlength="10" placeholder="驗證碼"/>
   <a class="get" href="#" id="sendCode">獲取</a>
   <label class="noVcode" id="notSms" hidden><i>10s</i><a href="#">|收不到驗證碼</a></label>
  </li>
  <li class="password bgImg">
   <input type="text" id="password" maxlength="10" placeholder="6-10位數字&字母組合登錄密碼"/>
   <a href="#" class="invisible bgImg"></a>
  </li>
 </ul>

後端邏輯實現

首先先做下說明,因為自己公司的框架部分,對整個項目做了三層框架的架構劃分,可同時支持iOS,Android,Web端.

首先去調取我要注冊的api接口部分

 1:調取register 注冊接口

doPost(proxy.apis.register, {}, {
  success:function (data) {
   $$('#Register').off();
   var btn = $$("#Register");
  }
 });

 2:這個是調取的api接口部分

 register:'/auth/register',   /*注冊*/
 login:'/auth/login',    /*登錄*/
 send_code:"/auth/getValidCode" /*發送驗證碼*/

 3:方法的定義放在最外面

 that.eventsHandler();
 that.registerSubmit();
 that.sendMessage();
 registerSubmit : function(){
   $('#Register').off('click').on('click',function(){
    // debugger;
    var phoneVal = $$.trim($$('#phone').val());
    var smsCodeVal = $$.trim($$('#smscode').val());
    var passwordVal = $$('#password').prop('value').trim();
    if (phoneVal == '') {
     popup('', '', '請輸入手機號');
     return false;
    }
    var verifyphone = __reg__.phone;
    if(!verifyphone.test(phoneVal)){
     popup('','','手機號碼格式錯誤');
     return false;
    }
    if (smsCodeVal == '') {
     popup('','','請發送短信驗證碼');
     return;
    }
    if (passwordVal == '') {
     popup('','','請輸入密碼');
     return;
    }
    $$("#Register").off('click');
   });
  },
  sendMessage : function () {
   var intervalInt;
   var sendCode = $$('#sendCode');
   var notSms = $$('#notSms');
   function sendFn() {
    sendCode.val(10).hide().off('click');
    notSms.show().off('click').on('click',notSms_click).css('color','#40cbff');
    intervalInt = setInterval(timeFn,1000);
    /*doPost(proxy.apis.send_code, {"phone":sendData.phone,"type":"borrowSms"}, {
     success:function (data) {
     if (data.status != '1') {
     popup('', '','發送短信出錯');
     }
     },
     error:function(data){
     popup('', '', data.msg);
     }
     });*/
   }
   function timeFn() {
    var secondVal = sendCode.val();
    sendCode.val(secondVal - 1);
    notSms.find('i').html(secondVal-1 + 's');
    if (sendCode.val() == 0 ) {
     // debugger
     notSms.hide();
     clearInterval(intervalInt);
     sendCode.show().on('click',sendFn);
    }
   }
   function notSms_click() {
    notSms.css('color','gray');
    dialog('獲取語音驗證碼', '驗證碼將以電話形式通知到你,請注意接聽喲~', 'OK', function () {
     $$('#notSms').off('click');
     doPost(proxy.apis.send_code, {"phone": phone, "type": "registerVoice"}, {
      success: function (data) {
       if (data.status != '1') {
        popup('', '', data.msg);
       }
      },
      error: errorFn
     });
    });
   }
   sendCode.off('click').on('click',sendFn);
  }

這裡列出一個和本文無關的但是有用的正則校驗:(name)姓名中帶點的·名字的校驗,如  買買提·古力娜扎·阿凡提

var __reg__ = {
 'name':/^[\u4E00-\u9FA5]+(·[\u4E00-\u9FA5]+)*$/,
 'phone':/^1[34578]\d{9}$/
};

這裡說一個timeFn() 方法,其實當我點開申請按鈕的時候,你看到的是秒數在倒計時,其實這裡做了2件事,第一是我給了一個數從60s開始,這個數值是寫死的,endCode.val(10).hide().off('click');,然後通過sendCode去取當前的秒數值,再依次做減法運算,直到秒數減到為0.在顯示 “申請”按鈕 sendCode.show().on('click',sendFn);

var secondVal = sendCode.val();
 sendCode.val(secondVal - 1);
 notSms.find('i').html(secondVal-1 + 's');

這樣就實現了一個驗證碼倒計時的效果,這裡提個醒:寫每個方法的時候,要看清是在內部寫還是在外部寫,是不是在方法的作用范圍內,不然click事件的觸發效果是不會實現出來的.

希望本文所述對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對網站的支持!

XML學習教程| jQuery入門知識| AJAX入門| Dreamweaver教程| Fireworks入門知識| SEO技巧| SEO優化集錦|
Copyright © DIV+CSS佈局教程網 All Rights Reserved