WEB开发之注册页面验证码倒计时代码的实现

作者:皮卡丘biubiubiu 时间:2024-04-22 22:32:31 

近期因为开发一个新的H5+backbone 项目,验证输入手机号 验证码倒计时功能。

WEB开发之注册页面验证码倒计时代码的实现WEB开发之注册页面验证码倒计时代码的实现

#如上图所示 要实现验证码的倒计时的效果

  • 首先做页面的布局

  • 理清楚页面效果需要实现的逻辑思路

  • 对手机号及验证码和密码做正则的规则校验

前端样式布局代码


<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事件的触发效果是不会实现出来的.

希望本文所述对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!

来源:http://blog.csdn.net/qq_33072593/article/details/53653220

标签:js,验证码,倒计时
0
投稿

猜你喜欢

  • 空行不空格式排版组织原理

    2010-05-03 14:46:00
  • mssql server 数据库附加不上解决办法分享

    2011-09-30 11:55:20
  • Oracle导出excel数据

    2023-07-18 17:44:14
  • Pytest执行unittest TestSuite(测试套件)的实现方法

    2023-12-23 06:05:14
  • Sqlserver2005日志文件太大如何减小

    2024-01-25 10:48:53
  • Python常见工厂函数用法示例

    2023-08-17 00:50:25
  • 如何使用yolov5输出检测到的目标坐标信息

    2021-07-12 17:25:14
  • Yolov5训练意外中断后如何接续训练详解

    2022-05-14 00:16:51
  • Python实现将照片变成卡通图片的方法【基于opencv】

    2023-06-08 11:32:54
  • 给年青设计师们的十条经验教训

    2011-03-31 17:09:00
  • 使用python创建Excel工作簿及工作表过程图解

    2021-10-05 03:57:34
  • 安装sql server 2008 management提示已安装 SQL Server 2005 Express的解决方法

    2024-01-15 12:49:03
  • 支持中文的Len, Left, Right函数

    2008-03-18 13:50:00
  • javascript使用call调用微信API

    2023-07-02 05:19:48
  • Python实现批量读取word中表格信息的方法

    2023-03-25 19:02:05
  • 浅谈JavaScript 中的延迟加载属性模式

    2024-04-17 10:29:56
  • MySQL批量更新的四种方式总结

    2024-01-13 17:53:08
  • python中关于range()函数反向遍历的几种表达

    2023-07-09 20:23:33
  • javaScript合并对象的几个常见方式

    2024-04-16 08:58:26
  • Select的OnChange()事件

    2009-03-03 12:40:00
  • asp之家 网络编程 m.aspxhome.com