vue按钮定时器

html

<el-button :disabled="disableBtn" @click="sendEmail" 
style="float:right;margin-top:3px;" type="success" size="mini">
{{emailBtnName}}
</el-button>

js


data(){
    return{
        emailBtnName: '获得验证码',
        disableBtn: false,
        btnTime: 0,
        circulationTimer: ''
    }
}


methods:{
        timerBtn(){
            if(this.btnTime>0){//进入倒计时
                this.btnTime--;
                this.emailBtnName = this.btnTime+'秒后重试!';
                this.circulationTimer = setTimeout(this.timerBtn,1000)
            }else{
                this.btnTime = 0;
                this.emailBtnName = '获得验证码'
                this.disableBtn = false
                clearTimeout(this.circulationTimer)
            }
        },
        sendEmail(){
            var verify = /^\w[-\w.+]*@([A-Za-z0-9][-A-Za-z0-9]+\.)+[A-Za-z]{2,14}/;
            if(this.registerName == ''){//验证邮箱
                    this.$message.warning('请输入邮箱!')
            }else if(!verify.test(this.registerName)){//验证邮箱格式是否正确
                this.$message.error('邮箱格式错误!')
            }else{//通过验证的邮箱
                this.disableBtn = true
                this.btnTime = 60
                this.timerBtn()
                //这里可以开始调用后台接口了
                alert('可以调后台接口了')
            }
        }
    }

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值