倒计时 不念不忘少年蓝@ 2022-06-02 10:12 416阅读 0赞 ### 验证输入手机号 验证码倒计时 ### ![这里写图片描述][SouthEast]![这里写图片描述][SouthEast 1] #### **\#如上图所示 要实现验证码的倒计时的效果** #### * **首先做页面的布局** * **理清楚页面效果需要实现的逻辑思路** * **对手机号及验证码和密码做正则的规则校验** -------------------- #### **前端样式布局代码** #### <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> 1 2 3 4 5 6 7 8 9 10 11 12 13 14 #### **后端逻辑实现** #### > 首先先做下说明,因为自己公司的框架部分,对整个项目做了三层框架的架构划分,可同时支持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(); 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 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); } 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 这里列出一个和本文无关的但是有用的正则校验:(name)姓名中带点的·名字的校验,如 买买提·古力娜扎·阿凡提 var __reg__ = { 'name':/^[\u4E00-\u9FA5]+(·[\u4E00-\u9FA5]+)*$/, 'phone':/^1[34578]\d{ 9}$/ }; 1 2 3 4 5 #### 这里说一个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'); 1 2 3 这样就实现了一个验证码倒计时的效果,这里提个醒:写每个方法的时候,要看清是在内部写还是在外部写,是不是在方法的作用范围内,不然click事件的触发效果是不会实现出来的. 今天的分享就到这里.更文将继续…….. #### **好的事情每天用心做一点,然后等待时间的回报O(∩\_∩)O~~** #### **转自:http://blog.csdn.net/qq\_33072593/article/details/53653220** [SouthEast]: https://img-blog.csdn.net/20161214235346065?watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvcXFfMzMwNzI1OTM=/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/SouthEast [SouthEast 1]: /images/20220602/28751c5833ae4fe29b8128c45fd9d3ed.png
相关 倒计时 js部分: export default function CalcTime(endtime) { var obj = {}; var 男娘i/ 2023年05月31日 06:38/ 0 赞/ 61 阅读
相关 C#倒计时 C\新手,记录一下倒计时,30s的倒计时,附上效果图 ![watermark_type_ZmFuZ3poZW5naGVpdGk_shadow_10_text_aHR0cHM6 柔光的暖阳◎/ 2023年01月19日 03:09/ 0 赞/ 320 阅读
相关 js 天数倒计时 时间倒计时 export function getOverTimeDown(endDateStr: string, outValue?: { value: string }, fn àì夳堔傛蜴生んèń/ 2022年09月11日 12:10/ 0 赞/ 336 阅读
相关 倒计时 验证输入手机号 验证码倒计时 ![这里写图片描述][SouthEast]![这里写图片描述][SouthEast 1] \如上图所示 要实现验证码的倒计时的效果 不念不忘少年蓝@/ 2022年06月02日 10:12/ 0 赞/ 417 阅读
相关 JS-实现秒表倒计时+缓存倒计时 实现秒表倒计时+缓存倒计时功能 <!DOCTYPE html> <html> <head> <meta ch 约定不等于承诺〃/ 2022年05月17日 12:38/ 0 赞/ 416 阅读
相关 倒计时程序 倒计时程序的设计 /对于一个数字倒计时的设计 问题描述:在日常工作中经常见到倒计时的设计,那么,如何设计倒计时呢? 给出一个数字,每隔一秒减一 红太狼/ 2022年04月02日 04:46/ 0 赞/ 375 阅读
相关 javascript倒计时 <script type="text/javascript"> clock();//一开始来去初始化倒计时 setI 阳光穿透心脏的1/2处/ 2022年01月26日 15:01/ 0 赞/ 365 阅读
相关 倒计时 js代码 var EndTime= new Date('2017/2/18 00:00:00'); //设置到期时间 var NowTime = ne - 日理万妓/ 2021年12月23日 08:41/ 0 赞/ 556 阅读
相关 js倒计时 ![20190820151447888.png][] function tow(n) { return n >= 0 && - 日理万妓/ 2021年10月19日 09:52/ 0 赞/ 493 阅读
相关 JS 倒计时 经常遇到需要倒计时的地方,下面的JS可以简单实现倒计时,当然可以加上Css使得界面更加美观! `<script type=` `"text/javascript"` `>` 约定不等于承诺〃/ 2021年09月29日 17:34/ 0 赞/ 594 阅读
还没有评论,来说两句吧...