欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

WEB開發(fā)之注冊(cè)頁(yè)面驗(yàn)證碼倒計(jì)時(shí)代碼的實(shí)現(xiàn)

 更新時(shí)間:2016年12月15日 09:33:25   作者:皮卡丘biubiubiu  
近期在搞一個(gè)H5+backbone 項(xiàng)目,驗(yàn)證輸入手機(jī)號(hào) 驗(yàn)證碼倒計(jì)時(shí)功能,代碼中包含了前端樣式布局代碼和后端邏輯實(shí)現(xiàn),思路明確,具有參考借鑒價(jià)值,需要的朋友參考下吧

近期因?yàn)殚_發(fā)一個(gè)新的H5+backbone 項(xiàng)目,驗(yàn)證輸入手機(jī)號(hào) 驗(yàn)證碼倒計(jì)時(shí)功能。

這里寫圖片描述這里寫圖片描述

#如上圖所示 要實(shí)現(xiàn)驗(yàn)證碼的倒計(jì)時(shí)的效果

  • 首先做頁(yè)面的布局
  • 理清楚頁(yè)面效果需要實(shí)現(xiàn)的邏輯思路
  • 對(duì)手機(jī)號(hào)及驗(yàn)證碼和密碼做正則的規(guī)則校驗(yàn)

前端樣式布局代碼

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

后端邏輯實(shí)現(xiàn)

首先先做下說(shuō)明,因?yàn)樽约汗镜目蚣懿糠?對(duì)整個(gè)項(xiàng)目做了三層框架的架構(gòu)劃分,可同時(shí)支持iOS,Android,Web端.

首先去調(diào)取我要注冊(cè)的api接口部分

 1:調(diào)取register 注冊(cè)接口

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

 2:這個(gè)是調(diào)取的api接口部分

 register:'/auth/register',   /*注冊(cè)*/
 login:'/auth/login',    /*登錄*/
 send_code:"/auth/getValidCode" /*發(fā)送驗(yàn)證碼*/

 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('', '', '請(qǐng)輸入手機(jī)號(hào)');
     return false;
    }
    var verifyphone = __reg__.phone;
    if(!verifyphone.test(phoneVal)){
     popup('','','手機(jī)號(hào)碼格式錯(cuò)誤');
     return false;
    }
    if (smsCodeVal == '') {
     popup('','','請(qǐng)發(fā)送短信驗(yàn)證碼');
     return;
    }
    if (passwordVal == '') {
     popup('','','請(qǐng)輸入密碼');
     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('', '','發(fā)送短信出錯(cuò)');
     }
     },
     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('獲取語(yǔ)音驗(yàn)證碼', '驗(yàn)證碼將以電話形式通知到你,請(qǐng)注意接聽喲~', '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);
  }

這里列出一個(gè)和本文無(wú)關(guān)的但是有用的正則校驗(yàn):(name)姓名中帶點(diǎn)的·名字的校驗(yàn),如  買買提·古力娜扎·阿凡提

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

這里說(shuō)一個(gè)timeFn() 方法,其實(shí)當(dāng)我點(diǎn)開申請(qǐng)按鈕的時(shí)候,你看到的是秒數(shù)在倒計(jì)時(shí),其實(shí)這里做了2件事,第一是我給了一個(gè)數(shù)從60s開始,這個(gè)數(shù)值是寫死的,endCode.val(10).hide().off('click');,然后通過(guò)sendCode去取當(dāng)前的秒數(shù)值,再依次做減法運(yùn)算,直到秒數(shù)減到為0.在顯示 “申請(qǐng)”按鈕 sendCode.show().on('click',sendFn);

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

這樣就實(shí)現(xiàn)了一個(gè)驗(yàn)證碼倒計(jì)時(shí)的效果,這里提個(gè)醒:寫每個(gè)方法的時(shí)候,要看清是在內(nèi)部寫還是在外部寫,是不是在方法的作用范圍內(nèi),不然click事件的觸發(fā)效果是不會(huì)實(shí)現(xiàn)出來(lái)的.

希望本文所述對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!

相關(guān)文章

  • JavaScript的原型存在的安全問(wèn)題及解決辦法

    JavaScript的原型存在的安全問(wèn)題及解決辦法

    JavaScript的原型很多人都知道也很好用,但是很多人在使用原型繼承中導(dǎo)致的安全問(wèn)題卻很少人知道,接下來(lái)我們就來(lái)好好了解一下,感興趣的小伙伴跟著小編一起來(lái)看看吧
    2023-08-08
  • js簡(jiǎn)單判斷flash是否加載完成的方法

    js簡(jiǎn)單判斷flash是否加載完成的方法

    這篇文章主要介紹了js簡(jiǎn)單判斷flash是否加載完成的方法,通過(guò)PercentLoaded方法對(duì)flash的加載進(jìn)行判斷,具有一定參考借鑒價(jià)值,需要的朋友可以參考下
    2016-06-06
  • js實(shí)現(xiàn)對(duì)ajax請(qǐng)求面向?qū)ο蟮姆庋b

    js實(shí)現(xiàn)對(duì)ajax請(qǐng)求面向?qū)ο蟮姆庋b

    這篇文章主要介紹了js實(shí)現(xiàn)對(duì)ajax請(qǐng)求面向?qū)ο蟮姆庋b的相關(guān)資料,需要的朋友可以參考下
    2016-01-01
  • javascript實(shí)現(xiàn)拖拽碰撞檢測(cè)

    javascript實(shí)現(xiàn)拖拽碰撞檢測(cè)

    這篇文章主要為大家詳細(xì)介紹了javascript實(shí)現(xiàn)拖拽碰撞檢測(cè),碰撞改變顏色,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-03-03
  • JavaScript 五大常見函數(shù)

    JavaScript 五大常見函數(shù)

    在javascript前端開發(fā)中js函數(shù)問(wèn)題經(jīng)常會(huì)被討論,這個(gè)問(wèn)題仁者見仁智者見智,下面通過(guò)示例代碼給大家介紹js五大常見函數(shù),感興趣的朋友一起看看吧
    2018-03-03
  • 下載站控制介紹字?jǐn)?shù)顯示的腳本 顯示全部 隱藏介紹等功能

    下載站控制介紹字?jǐn)?shù)顯示的腳本 顯示全部 隱藏介紹等功能

    有一些下載網(wǎng)站為了整體的統(tǒng)一,盡量的控制軟件介紹的字?jǐn)?shù)顯示,要不因?yàn)樽謹(jǐn)?shù)介紹太多導(dǎo)致用戶看到下載鏈接比較靠后等原因而一個(gè)小功能的實(shí)現(xiàn)。
    2009-09-09
  • javascript從image轉(zhuǎn)換為base64位編碼的String

    javascript從image轉(zhuǎn)換為base64位編碼的String

    選擇webview把image以base64位編碼的方式傳給本地應(yīng)用,就不需要再取一次圖片文件了,從而提高了速度
    2014-07-07
  • javascript表單是否為空驗(yàn)證方法

    javascript表單是否為空驗(yàn)證方法

    表單驗(yàn)證在很多地方都可以用到,本文詳細(xì)的介紹了javascript表單是否為空驗(yàn)證方法,文中通過(guò)示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-03-03
  • 如何寫好你的JavaScript【推薦】

    如何寫好你的JavaScript【推薦】

    在實(shí)際工作中,我們應(yīng)該經(jīng)常會(huì)看到一些功能上沒(méi)有問(wèn)題,但編碼風(fēng)格和規(guī)范卻十分糟糕的代碼,這往往會(huì)讓人不敢再往下閱讀,甚至?xí)绊戦喿x者一天的心情。本文的目的在于幫助那些沒(méi)有養(yǎng)成良好的編碼風(fēng)格,缺乏相應(yīng)編碼規(guī)范意識(shí)的JavaScript學(xué)習(xí)者們改善他們的編碼形象。
    2017-03-03
  • 用js怎么把&字符換成"&amp:"

    用js怎么把&字符換成"&amp:"

    用js怎么把&字符換成"&amp:"...
    2006-10-10

最新評(píng)論