欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

vue获取验证码倒计时组件

程序员文章站 2024-01-17 14:41:22
本文实例为大家分享了vue获取验证码倒计时组件,供大家参考,具体内容如下 之前写过一个计时函数,有计算误差,但是验证码的60秒倒计时可以忽略这一点点误差。直接上代码。...

本文实例为大家分享了vue获取验证码倒计时组件,供大家参考,具体内容如下

之前写过一个计时函数,有计算误差,但是验证码的60秒倒计时可以忽略这一点点误差。直接上代码。

vue获取验证码倒计时组件

<template>
 <div class="captcha-row">
  <input class="captcha-input" placeholder="输入验证码" auto-focus />
  <div v-if="showtime===null" class="captcha-button" @click="send">
   获取验证码
  </div>
  <div v-else class="captcha-button">
   {{showtime}}
  </div>
 </div>
</template>
<script>
export default {
 data() {
  return {
   // 计时器,注意需要进行销毁
   timecounter: null,
   // null 则显示按钮 秒数则显示读秒
   showtime: null
  }
 },
 methods: {
  // 倒计时显示处理
  countdowntext(s) {
   this.showtime = `${s}s后重新获取`
  },
  // 倒计时 60秒 不需要很精准
  countdown(times) {
   const self = this;
   // 时间间隔 1秒
   const interval = 1000;
   let count = 0;
   self.timecounter = settimeout(countdownstart, interval);
   function countdownstart() {
    if (self.timecounter == null) {
     return false;
    }
    count++
    self.countdowntext(times - count + 1);
    if (count > times) {
     cleartimeout(self.timecounter)
     self.showtime = null;
    } else {
     self.timecounter = settimeout(countdownstart, interval)
    }
   }
  },
  send() {
   this.countdown(60);
  }
 },
}
</script>
<style lang="less" scoped>
.captcha-row {
 display: flex;
 .captcha-button {
  background: #048fff;
  color: white;
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 4rpx 8rpx;
  width: 320rpx;
  border-radius: 4rpx;
 }
}
</style>

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。