五秒内点击屏幕8次触发事件

实现思路如下:
五秒内点击八次,核心是时间控制在五秒内,如果超过时间要及时重置计数器,以获取最佳用户体验。
1.困难点:没有及时去重置时间。场景:有的用户先点三次,过三分钟后回来点五次。如果我们没有及时的重置计数器,这会导致用户点完五次后,告诉用户超时了,要再次重新连续点八次。
本案例旨在解决此类问题。

html片段
<div class="foot" @touchstart='touchstart'></div>
data中数据

data() {
    return{
      num:0,
      startTime: '',
      lastTime: ''
    }
  },

methods:

touchstart(e) {
      if(this.num === 0) {
        this.startTime = new Date()
        this.lastTime = this.startTime
      } else if (this.num>=1) {
        let nextTime = new Date()
        if((nextTime - this.lastTime)>=3000 || (nextTime - this.startTime)>=5000){
          console.log('重置')
          this.startTime = nextTime
          this.lastTime = nextTime
          this.num = 0
        }else{
          this.lastTime = nextTime
        }
        if(this.num === 7){
          console.log('suc')
          localStorage.setItem('isShow',true)
          this.$router.push('/end_login')
        }
      }
      this.num++
      console.log(this.num)
    }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值