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

发布时间 - 2026-01-10 21:50:09    点击率:

近期因为开发一个新的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事件的触发效果是不会实现出来的.

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


# 获取验证码倒计时代码  # js实现验证码倒计时  # JS实现用户注册时获取短信验证码和倒计时功能  # JS实现表单验证功能(验证手机号是否存在  # 验证码倒计时)  # 基于JS实现发送短信验证码后的倒计时功能(无视页面刷新  # 页面关闭不进行倒计时功能)  # JS/jQ实现免费获取手机验证码倒计时效果  # js实现点击获取验证码倒计时效果  # js实现发送验证码后的倒计时功能  # 验证码  # 倒计时  # 请输入  # 发送短信  # 的是  # 我要  # 是在  # 放在  # 在此  # 给了  # 要看  # 到你  # 请注意  # 将以  # 所示  # 件事  # 所述  # 小编  # 我点  # 带点 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: 如何用手机制作网站和网页,手机移动端的网站能制作成中英双语的吗?  Laravel怎么多语言本地化设置_Laravel语言包翻译与Locale动态切换【手册】  如何快速搭建自助建站会员专属系统?  Laravel如何发送邮件_Laravel Mailables构建与发送邮件的简明教程  使用spring连接及操作mongodb3.0实例  Laravel怎么配置自定义表前缀_Laravel数据库迁移与Eloquent表名映射【步骤】  Thinkphp 中 distinct 的用法解析  企业网站制作这些问题要关注  Laravel怎么实现模型属性的自动加密  Laravel如何设置自定义的日志文件名_Laravel根据日期或用户ID生成动态日志【技巧】  网站制作企业,网站的banner和导航栏是指什么?  JS中对数组元素进行增删改移的方法总结  如何在腾讯云服务器上快速搭建个人网站?  Laravel怎么发送邮件_Laravel Mail类SMTP配置教程  QQ浏览器网页版登录入口 个人中心在线进入  如何自定义建站之星模板颜色并下载新样式?  Laravel怎么创建自己的包(Package)_Laravel扩展包开发入门到发布  EditPlus中的正则表达式 实战(2)  实例解析angularjs的filter过滤器  Laravel全局作用域是什么_Laravel Eloquent Global Scopes应用指南  标题:Vue + Vuex 项目中正确使用 JWT 进行身份认证的实践指南  今日头条微视频如何找选题 今日头条微视频找选题技巧【指南】  javascript日期怎么处理_如何格式化输出  网站制作公司哪里好做,成都网站制作公司哪家做得比较好,更正规?  北京网页设计制作网站有哪些,继续教育自动播放怎么设置?  Laravel如何使用查询构建器?(Query Builder高级用法)  edge浏览器无法安装扩展 edge浏览器插件安装失败【解决方法】  Swift中switch语句区间和元组模式匹配  百度输入法全感官ai怎么关 百度输入法全感官皮肤关闭  如何在云服务器上快速搭建个人网站?  详解免费开源的DotNet二维码操作组件ThoughtWorks.QRCode(.NET组件介绍之四)  零基础网站服务器架设实战:轻量应用与域名解析配置指南  Win11怎么修改DNS服务器 Win11设置DNS加速网络【指南】  青岛网站建设如何选择本地服务器?  JS实现鼠标移上去显示图片或微信二维码  手机网站制作与建设方案,手机网站如何建设?  HTML透明颜色代码在Angular里怎么设置_Angular透明颜色使用指南【详解】  Win11摄像头无法使用怎么办_Win11相机隐私权限开启教程【详解】  在Oracle关闭情况下如何修改spfile的参数  软银砸40亿美元收购DigitalBridge 强化AI资料中心布局  如何快速登录WAP自助建站平台?  关于BootStrap modal 在IOS9中不能弹出的解决方法(IOS 9 bootstrap modal ios 9 noticework)  制作企业网站建设方案,怎样建设一个公司网站?  1688铺货到淘宝怎么操作 1688一键铺货到自己店铺详细步骤  如何确认建站备案号应放置的具体位置?  韩国服务器如何优化跨境访问实现高效连接?  Laravel如何监控和管理失败的队列任务_Laravel失败任务处理与监控  东莞专业网站制作公司有哪些,东莞招聘网站哪个好?  Laravel如何处理和验证JSON类型的数据库字段  瓜子二手车官方网站在线入口 瓜子二手车网页版官网通道入口