WEB開發(fā)之注冊頁面驗(yàn)證碼倒計(jì)時代碼的實(shí)現(xiàn)
近期因?yàn)殚_發(fā)一個新的H5+backbone 項(xiàng)目,驗(yàn)證輸入手機(jī)號 驗(yàn)證碼倒計(jì)時功能。


#如上圖所示 要實(shí)現(xiàn)驗(yàn)證碼的倒計(jì)時的效果
- 首先做頁面的布局
- 理清楚頁面效果需要實(shí)現(xiàn)的邏輯思路
- 對手機(jī)號及驗(yàn)證碼和密碼做正則的規(guī)則校驗(yàn)
前端樣式布局代碼
<ul> <li class="phone bgImg"> <input type="text" id="phone" maxlength="11" placeholder="手機(jī)號"/> </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)
首先先做下說明,因?yàn)樽约汗镜目蚣懿糠?對整個項(xiàng)目做了三層框架的架構(gòu)劃分,可同時支持iOS,Android,Web端.
首先去調(diào)取我要注冊的api接口部分
1:調(diào)取register 注冊接口
doPost(proxy.apis.register, {}, {
success:function (data) {
$$('#Register').off();
var btn = $$("#Register");
}
});
2:這個是調(diào)取的api接口部分
register:'/auth/register', /*注冊*/ 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('', '', '請輸入手機(jī)號');
return false;
}
var verifyphone = __reg__.phone;
if(!verifyphone.test(phoneVal)){
popup('','','手機(jī)號碼格式錯誤');
return false;
}
if (smsCodeVal == '') {
popup('','','請發(fā)送短信驗(yàn)證碼');
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('', '','發(fā)送短信出錯');
}
},
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àn)證碼', '驗(yàn)證碼將以電話形式通知到你,請注意接聽喲~', '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);
}
這里列出一個和本文無關(guān)的但是有用的正則校驗(yàn):(name)姓名中帶點(diǎn)的·名字的校驗(yàn),如 買買提·古力娜扎·阿凡提
var __reg__ = {
'name':/^[\u4E00-\u9FA5]+(·[\u4E00-\u9FA5]+)*$/,
'phone':/^1[34578]\d{9}$/
};
這里說一個timeFn() 方法,其實(shí)當(dāng)我點(diǎn)開申請按鈕的時候,你看到的是秒數(shù)在倒計(jì)時,其實(shí)這里做了2件事,第一是我給了一個數(shù)從60s開始,這個數(shù)值是寫死的,endCode.val(10).hide().off('click');,然后通過sendCode去取當(dāng)前的秒數(shù)值,再依次做減法運(yùn)算,直到秒數(shù)減到為0.在顯示 “申請”按鈕 sendCode.show().on('click',sendFn);
var secondVal = sendCode.val();
sendCode.val(secondVal - 1);
notSms.find('i').html(secondVal-1 + 's');
這樣就實(shí)現(xiàn)了一個驗(yàn)證碼倒計(jì)時的效果,這里提個醒:寫每個方法的時候,要看清是在內(nèi)部寫還是在外部寫,是不是在方法的作用范圍內(nèi),不然click事件的觸發(fā)效果是不會實(shí)現(xiàn)出來的.
希望本文所述對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
- JS實(shí)現(xiàn)用戶注冊時獲取短信驗(yàn)證碼和倒計(jì)時功能
- JS實(shí)現(xiàn)表單驗(yàn)證功能(驗(yàn)證手機(jī)號是否存在,驗(yàn)證碼倒計(jì)時)
- 基于JS實(shí)現(xiàn)發(fā)送短信驗(yàn)證碼后的倒計(jì)時功能(無視頁面刷新,頁面關(guān)閉不進(jìn)行倒計(jì)時功能)
- JS/jQ實(shí)現(xiàn)免費(fèi)獲取手機(jī)驗(yàn)證碼倒計(jì)時效果
- js實(shí)現(xiàn)點(diǎn)擊獲取驗(yàn)證碼倒計(jì)時效果
- js實(shí)現(xiàn)發(fā)送驗(yàn)證碼后的倒計(jì)時功能
相關(guān)文章
js實(shí)現(xiàn)對ajax請求面向?qū)ο蟮姆庋b
這篇文章主要介紹了js實(shí)現(xiàn)對ajax請求面向?qū)ο蟮姆庋b的相關(guān)資料,需要的朋友可以參考下2016-01-01
下載站控制介紹字?jǐn)?shù)顯示的腳本 顯示全部 隱藏介紹等功能
有一些下載網(wǎng)站為了整體的統(tǒng)一,盡量的控制軟件介紹的字?jǐn)?shù)顯示,要不因?yàn)樽謹(jǐn)?shù)介紹太多導(dǎo)致用戶看到下載鏈接比較靠后等原因而一個小功能的實(shí)現(xiàn)。2009-09-09
javascript從image轉(zhuǎn)換為base64位編碼的String
選擇webview把image以base64位編碼的方式傳給本地應(yīng)用,就不需要再取一次圖片文件了,從而提高了速度2014-07-07

