验证码倒计时

阿逗 2017-03-21

函数

  实际开发中,验证码的验证,现在各大网站都是必须的,什么手机验证码验证,邮箱验证等。今天遇到一个例子,特地记录一下。

     模拟HTML结构,实际要复杂的多。

  HTML结构很简单,就是两个按钮,有不同的id,如下:

<button id="btn">手机验证码</button>
<button id="btn2">邮箱验证码</button>

  为了简化dom操作,我们引入jQuery,js 代码如下:

function settime(val,verify_type,setTimeNumber) {
    if (setTimeNumber== 0) {
        val.removeAttribute("disabled");
        val.innerHTML = verify_type;
        setTimeNumber= setTimeNumber
; } else { val.setAttribute("disabled", true);
val.innerHTML
= "重新发送(" + setTimeNumber + ")";
setTimeNumber
--;
setTimeout(
function() {
settime(val,verify_type,setTimeNumber);
},
1000);
} }
$(
"#btn").click(function(){ settime(this,"手机验证码",10);
})
$(
"#btn2").click(function(){ settime(this,"邮箱验证码",20); })

  这里对函数稍稍的封装了一下,因为我们想在实际的开发中,只要是验证码的业务,都用一套Js,所以,封装少不了,当然我这里是简单的,有更好的封装方法,可以评论留言,我们相互学习。我把验证的类型和验证的时间分开写,作为参数传入,目的就是在调用的时候,对不同的对象采用同一种方法,只要传入不同的参数就可以实现,这就是js中的封装和多态的思想。

  代码中,用了if的判断,只要 setTimeNumber 的值是0,那么就是倒计时结束,我们就让这个按钮可以点击了,移出“disabled”的属性。val.removeAttribute("disabled");

如果不是为0的值,(当然,在传入的时候,必须是正整数,不过我们也可以在函数里判断,如果传入的参数不是正整数,就return 等处理。),我们就让这个值减一,调用定时器来处理,让定时器,调用这个函数,知道setTimeNumber为0,同时在倒计时的时候,按钮是不可点击的,因此,给它要添加disabled的属性。

每日一句:Today is a long time away from the chaotic 1970s, but Wolverine seems no less relevant in the age of President Trump. As Alex Godfrey of Empire magazine wrote: “Wolverine was created in a dark, uncertain time of political upheaval. We don’t want him going anywhere.

翻译:今天离混乱的上世纪70年代已经很远了,但金刚狼似乎仍和特朗普的总统时代息息相关。正如《帝国》杂志的亚历克斯·戈弗雷所写的那样:“金刚狼创造于一个黑暗、动荡的政治巨变年代。我们不想让他远离。”

 

登录 后评论
下一篇
云栖号资讯小编
33792人浏览
2020-07-13
相关推荐
换绑中交互的注意事项
1131人浏览
2016-05-11 10:43:05
获取验证码倒计时,js代码
923人浏览
2015-11-03 11:26:42
短信验证码实现(转)
989人浏览
2016-05-25 22:30:00
网页脚本注入执行任意代码
2036人浏览
2017-11-26 20:25:32
js 发送验证码倒计时
1284人浏览
2018-06-27 14:44:00
IONIC3验证码倒计时按钮实现
784人浏览
2017-10-23 21:51:00
0
0
0
853