WEB开发之注册页面验证码倒计时代码的实现
作者:皮卡丘biubiubiu 发布时间:2024-04-22 22:32:31
标签:js,验证码,倒计时
近期因为开发一个新的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事件的触发效果是不会实现出来的.
希望本文所述对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!
来源:http://blog.csdn.net/qq_33072593/article/details/53653220
0
投稿
猜你喜欢
- networkx是Python的一个包,用于构建和操作复杂的图结构,提供分析图的算法。图是由顶点、边和可选的属性构成的数据结构,顶点表示数据
- ThinkPHP CURD方法的limit方法也是模型类的连贯操作方法之一,主要用于指定查询和操作的数量,特别在分页查询的时候使用较多。并且
- 查看隐藏参数SELECT x.ksppinm name,y.ksppstvl value,y.ksppstdf isdefault,deco
- ValueError: The number of FixedLocator locations (9), usually from a c
- 本文实例讲述了Python让字典保持有序的方法。分享给大家供大家参考,具体如下:问题:创建一个字典,同时对字典做迭代或序列化操作时,也能控制
- think-queue是ThinkPHP官方提供的一个消息队列服务,是专门支持队列服务的扩展包。think-queue消息队列适用于大并发或
- 前面我们用python实现了贪吃蛇、坦克大战、飞船大战、五子棋等游戏今天我们用python来实现一下扫雷游戏本游戏代码量和源文件较多可以从我
- Python 实现微信小程序的用户登录小程序可以通过官方提供的登录邓丽来获取用户身份的标示, 具体文档可以参考 官方文档, 通过流程时序可以
- 现实生活中,有很多场景中的事情是同时进行的,比如开车的时候,手和脚共同来驾驶汽车,再比如唱歌跳舞也是同时进行的。以上这些可以理解为多任务。那
- 前几天,我们用虚拟机安装了Ubuntu 20.04。今天,我们来安装一些常用的工具,比如Pycharm。 Pycharm是一种用来开发Pyt
- 本文实例讲述了php中debug_backtrace、debug_print_backtrace和匿名函数用法。分享给大家供大家参考。具体分
- 可以把多个页面相同的部分提取出来,放在一个母板里,这些页面只需要继承这个母板就好了通常会在母板中定义页面专用的 CSS 块和 JS 块,方便
- 目录一、语法简介二、完整代码一、语法简介plt.legend(loc=2,edgecolor='red',facecolor
- Python 操作文件编程语言对文件系统的操作是一项必不可少的功能,各种编程语言基本上都有对文件系统的操作,最简洁的莫过于linux里面sh
- 我们来编写一个,引用时用:<!--#include Virtual="page.inc"-->语句即可:pa
- 以下函数代码中“123456” 是个加密的key,自己可以随便改。php加密,js解密,貌似没什么意义,主要是key在js中会被看到。不过在
- 背景重装系统,发现之前装在E盘的python可以直接使用,就只是将python的安装目录加入到环境变量中,也一直没有管它,今天跟天软交互的时
- 如下所示:import timedef date_compare(item1, item2): t1 = time.mktime(time.
- 开始安装Androidstudio 4.1克隆此项目git clone https://github.com/pytorch/android
- 当我们再训练网络的时候可能希望保持一部分的网络参数不变,只对其中一部分的参数进行调整;或者值训练部分分支网络,并不让其梯度对主网络的梯度造成