jQuery实现验证码60秒倒计时

jQuery实现验证码60秒倒计时##

在lib.dom.d.ts中有setInterval和setTimeout两种定时器的声明:

declare function setInterval(handler: (...args: any[]) => void, timeout: number): number;
declare function setInterval(handler: any, timeout?: any, ...args: any[]): number;
declare function setTimeout(handler: (...args: any[]) => void, timeout: number): number;
declare function setTimeout(handler: any, timeout?: any, ...args: any[]): number;

两者定时器的区别在于:
setInterval以指定时间为周期循环执行
setTimeout只在指定时间后执行一次

实现短信或者邮箱发送验证码60秒倒计时功能的时候,大多数使用的是以下这种比较好理解的方法,用的是setTimeout:

function invokeSettime(obj){
    var countdown=60;
    settime(obj);
    function settime(obj) {
        if (countdown == 0) {
            $(obj).attr("disabled",false);
            $(obj).text("获取验证码");
            countdown = 60;
            return;
        } else {
            $(obj).attr("disabled",true);
            $(obj).text("(" + countdown + ") s 重新发送");
            countdown--;
        }
        setTimeout(function() {
                    settime(obj) }
                ,1000)
    }
}

但是我感觉使用setInterval的写法能更简洁一些,也推荐大家采用:

function resendCpatcha (btnEle, countdown){
        btnEle.text('发送验证码' + '(' + countdown + ')');
        var t = setInterval(function() {
            if (--countdown === 0){
                clearInterval(t);
                btnEle.attr('disabled',false);
                btnEle.text('重新发送验证码');
            } else{
                btnEle.attr('disabled',true);
                btnEle.text('发送验证码' + '(' + countdown + ')');
            }
        }, 1000);
    }
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Algorithm_goddness

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值