首页 > 代码库 > 验证码倒计时

验证码倒计时

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

     模拟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= 10;
    } 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年代已经很远了,但金刚狼似乎仍和特朗普的总统时代息息相关。正如《帝国》杂志的亚历克斯·戈弗雷所写的那样:“金刚狼创造于一个黑暗、动荡的政治巨变年代。我们不想让他远离。”

 

验证码倒计时