VUE倒计时组件

常用于发送短信、邮件后1分钟倒计时,倒计时结束后又可以再次点击

vue组件封装:

<template>
  <div class="timer-btn">
    <button
      class="sendSmsBtn"
      :class="disabled?'disableSendSmsBtn':''"
      type="button"
      @click="run"
      :disabled="disabled || time > 0"
    >{{ text }}</button>
  </div>
</template>

<script>
export default {
  name: 'TTimer',
  props: {
    second: {
      type: Number,
      default: 60
    },
    start: {
      type: Boolean,
      default: false,
    }
  },
  watch: {
    start(status) {
      if (status) {
        this.go()
      }
    },
  },
  data() {
    return {
      time: 0,
      disabled: false
    }
  },
  computed: {
    text() {
      return this.time > 0 ? `${this.time}s 后重获取` : '获取验证码'
    }
  },
  methods: {
    run() {
      this.$emit('click')
    },
    go() {
      this.time = this.second
      this.disabled = true
      this.timer()
    },
    timer() {
      if (this.time > 0) {
        this.time--
        setTimeout(this.timer, 1000)
      } else {
        this.disabled = false
        this.$emit('end')
      }
    }

  }
}
</script>
<style lang="scss" scoped>
.timer-btn {
  position: relative;
  .sendSmsBtn {
    height: 40px;
    line-height: 40px;
    border-radius: 4px;
    font-size:14px;
    background-color:#ecf5ff;
    border: 1px solid #b3d8ff;
    padding: 0 6px;
    color: #409eff;
    font-weight: 500;
    display: inline-block;
    width:100%;
    min-width: 92px;
    cursor: pointer;
  }
  .disableSendSmsBtn {
    opacity: 0.5;
    cursor: auto;
  }
}
</style>

调用
<t-timer v-else :second="60" @click="getCode" :start="startCountdown" @end="handleEnd"/>

我这儿用的getCode方法请求后台短信、startCountdown标志true或false状态可以开始啦, handleEnd方法用来标记倒计时结束后修改startCountdown状态

标签: VUE, Javascript

相关文章

一些编程语言学习心得

作为一名专注于PHP、Go、Java和前端开发(JavaScript、HTML、CSS)的开发者,还得会运维、会谈客户....不想了,都是泪,今天说说这些年学习编程语言的一些体会,不同编程语言在...

Javascript封装WebRTC及使用教程

好的,我们将在现有基础上加入接听对话、加入多人对话、创建多人对话等功能,并重新生成完整的文章内容。WebRTC 封装及使用教程WebRTC 是一个强大的实时通信 API,允许在浏览器中进行音视频...

浏览器指纹识别的 JavaScript 库 - FingerprintJS

FingerprintJS 是一个用于浏览器指纹识别的 JavaScript 库。它通过收集浏览器和设备的各种特征来生成一个唯一的标识符,即“指纹”。这个指纹可以用于识别和跟踪用户,即使他们清除...

在JavaScript或Vue中屏蔽所有报错信息

在 JavaScript 或 Vue 中,如果你想屏蔽所有 JavaScript 报错,可以通过捕获全局的错误事件来实现。需要注意的是,尽量避免屏蔽所有错误,因为这可能会掩盖一些实际问题,影响调...

浏览器的开发工具中有个jsContext是什么

什么是 jsContext?在JavaScript中,jsContext 并不是一个官方的术语或概念。通常情况下,开发者可能会提到 context 这个词,它通常指的是执行上下文(Executi...

图片Base64编码

CSR生成

图片无损放大

图片占位符

Excel拆分文件