js设置连续点击N次才触发某个交互操作(如弹出信息面板

原文链接:https://dsx2016.com/?p=3153

公众号:大师兄2016

使用场景

仅在测试环境下,点击某个透明区域,连续点击N次,弹出调试信息面板

js代码示例

单页html测试

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>clickContinuity</title>
</head>

<body>
    <button onclick="clickContinuity()">连续点击</button>
</body>

<script>
    // 设置定时器
    let timer = null
    // 设置初始点击计数
    let clickCountNow = 0
    // clickTatgatNum(连续点击N次触发xxx)
    function clickContinuity(clickTatgatNum = 5) {
        // 连续点击次数小于指定次数时
        if (clickCountNow < clickTatgatNum - 1) {
            // 清除定时器
            if (timer) {
                clearTimeout(timer)
                timer = null
            }
            // 点击次数+1
            clickCountNow++
            // 打印次数日志
            console.log(`clickCountNow`, clickCountNow)
            // 设置定时器,大于300毫秒点击不算连续点击
            timer = setTimeout(() => {
                clickCountNow = 0
            }, 300)
        } else {
            // 点击次数+1(此时已大于等于指定点击次数)
            clickCountNow++
            // 打印日志
            console.log(`连续点击了${clickCountNow}次`, `做点什么`)
            // 清除定时器
            if (timer) {
                clearTimeout(timer)
                timer = null
            }
            // 点击次数归零,重新计数
            clickCountNow = 0

        }

    }
</script>

</html>

示例效果

代码示例动态演示

 

Tips

一些设置

  1. 连续点击时间300毫秒可以根据实际情况调整
  2. 连续点击次数N可以根据实际情况调整

还有一个附加条件

3秒内(限定总时间)连续点击5次,本文不做代码示例

END.

 

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值