註冊頁面 , 驗證碼倒計時代碼的實現

近期因爲開發一個新的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事件的觸發效果是不會實現出來的.

今天的分享就到這裏.更文將繼續……..

好的事情每天用心做一點,然後等待時間的回報O(∩_∩)O~~

發佈了31 篇原創文章 · 獲贊 48 · 訪問量 13萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章