码迷,mamicode.com
首页 > 其他好文 > 详细

验证码倒计时

时间:2017-03-21 22:42:20      阅读:208      评论:0      收藏:0      [点我收藏+]

标签:span   ted   rem   move   相互   htm   was   对象   btn   

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

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

 

验证码倒计时

标签:span   ted   rem   move   相互   htm   was   对象   btn   

原文地址:http://www.cnblogs.com/adouwt/p/6597084.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!