vue实现按钮倒计时功能

今天突发奇想写个手机号注册的功能。当我可以通过前端的按钮发送短信之后,想起了网爆的最基础方式,疯狂发送验证码短信。于是乎为了保护我那少的可怜的几条短信(还是白嫖的腾讯云的),需要做到前端的按钮只能够一分钟点一下(有人说我完全可以通过F12直接查看请求,然后postman疯狂发送。那种情况再说,今天就做一个在前端限制点击的按钮)。

<el-form-item label="验证码" prop="verificationCode" >
  <el-input type="text" v-model="ruleForm.verificationCode" placeholder="验证码" style="width: 80%;">
   <el-button slot="append" :disabled="!canClick" @click="getVerificationCode">{{ getCode }}</el-button>
  </el-input>
</el-form-item>

data(){
  return {
    getCode:'获取验证码',
    canClick:true, // 验证码是否禁用
    totalTime:60
  }
}

methods:{
  //倒计时
 verificationCode () {
   if (!this.canClick) return  
   this.canClick = false
   this.getCodeText = this.totalTime + 's后重新发送'
   let clock = window.setInterval(() => {
     this.totalTime--
     this.getCodeText = this.totalTime + 's后重新发送'
     if (this.totalTime < 0) {
       window.clearInterval(clock)
       this.getCodeText = '重新发送验证码'
       this.totalTime = 60
       this.canClick = true  
     }
   },1000)
 }
}

不要问我verificationCode这个方法用在哪里,你猜你猜啊(必然是只在发送验证码成功后才开始倒计时啊,发送验证码的方法axios)

实现效果:

在这里插入图片描述

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值