通过vue写一个按钮倒计时

9 篇文章 0 订阅

        由于写的项目用到element-ui,所以用到element-ui中的标签

    <template>

                <el-button 

                :disabled="!isClickCode" 

                type="primary" 

                @click="getCode()" 

                style="margin-left:10px;">{{codeText}}</el-button>

   </template>

data部分

        codeText:'获取验证码',    //获取验证码按钮的文字

        isClickCode:true,       //是否能点击获取验证码

methods部分

        async getCode(){

      //判断phone是否为手机号的正则表达式

      let pattern = /^1[34578]\d{9}$/

      if(pattern.test(this.phone)){//手机号格式正确,进入判断

        try {

          //发送请求获取验证码

          const result = await this.$store.dispatch('getCode',this.phone)

          //将获取的验证码赋值给data中的code

          this.code = result

          //获取成功提示

          this.$message.success('验证码获取成功')

          //再次可点击的按钮时间

          let num = 60

          //开启定时器,倒计时,并将按钮变为不可用

          let timer = setInterval( () =>{

            //按钮不可用

            this.isClickCode =false

            this.codeText = num + '秒后重新获取'

            num--

            if (num <= 0) {//60s结束,可重新获取验证码

              this.codeText = '重新获取验证码'

              //按钮可用

              this.isClickCode =true

              //清除定时器

              clearInterval(timer)

            }

          }, 1000)

        } catch (error) {

          alert('错误原因:'+error.message)

        }

      }

      else{

        this.$message.error('请输入正确的手机号')

      }

    },

若仅使用功能,将vuex部分的的代码去除即可使用

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值