Vue实现倒计时小功能

2022-04-15 0 448

很多项目中都需要实现倒计时功能,例:发送验证码。现在举例实现一个简单的倒计时按钮功能。简单布局,简单操作,简单效果,最主要的是思路和倒计时步骤理解!!!

例、代码如下:

要求:点击提交按钮倒计时五秒,倒计时期间输入框和提交按钮禁用,倒计时结束后输入框和提交按钮再变成正常状态

1、先实现要求的html布局,添加点击事件

<div>
    <!-- disabled为true禁用 -->
    输入框:<input type="text" :disabled="istrue">
    <button @click="addHandle" :disabled="istrue">提交</button>
    <!-- 倒计时文字提示 -->
    <p>{{this.txt}}</p>
</div>

2、点击提交按钮倒计时开始变禁用状态,定义一个计时器

<script>
export default {
  data(){
    return {
      txt:'',
      istrue:false,
      inp:''
    }
  },
  methods:{
    addHandle(){
      //定义n=5秒
      let n=5
      //定义定时器time
      let time=setInterval(()=>{
        //禁用
        this.istrue=true
        //改变倒计时文字提示
        this.txt=n+'秒后提交'
        n--
        //如果n<0,清除定时器,禁用状态取消,文字提示为空(不显示)
        if(n<0){
          this.txt=""
          this.istrue=false
          clearInterval(time)
        }
      },1000)
    }
  }
}
</script>

思路步骤都写在上方注释里了,一个简单的倒计时就这样轻易实现了。

整体代码:

<template>
  <div>
    <!-- disabled为true禁用 -->
    输入框:<input type="text" :disabled="istrue">
    <button @click="addHandle" :disabled="istrue">提交</button>
    <!-- 倒计时文字提示 -->
    <p>{{this.txt}}</p>
  </div>
</template>
<script>
export default {
  data(){
    return {
      txt:'',
      istrue:false,
      inp:''
    }
  },
  methods:{
    addHandle(){
      //定义n=5秒
      let n=5
      //定义定时器time
      let time=setInterval(()=>{
        //禁用
        this.istrue=true
        //改变倒计时文字提示
        this.txt=n+'秒后提交'
        n--
        //如果n<0,清除定时器,禁用状态取消,文字提示为空(不显示)
        if(n<0){
          this.txt=""
          this.istrue=false
          clearInterval(time)
        }
      },1000)
    }
  }
}
</script>

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

免责声明:
1、本网站所有发布的源码、软件和资料均为收集各大资源网站整理而来;仅限用于学习和研究目的,您必须在下载后的24个小时之内,从您的电脑中彻底删除上述内容。 不得使用于非法商业用途,不得违反国家法律。否则后果自负!

2、本站信息来自网络,版权争议与本站无关。一切关于该资源商业行为与www.niceym.com无关。
如果您喜欢该程序,请支持正版源码、软件,购买注册,得到更好的正版服务。
如有侵犯你版权的,请邮件与我们联系处理(邮箱:skknet@qq.com),本站将立即改正。

NICE源码网 JavaScript Vue实现倒计时小功能 https://www.niceym.com/24198.html