JavaScript 如何统计一段时间内鼠标点击次数

设计这么一个程序:如果在5秒钟之内用户用鼠标点击按钮的次数超过10次,则弹出提示,如果点击速度慢则可以无限制点击次数。主要是不给用户“猛点击”,提供个算法思路也行。... 设计这么一个程序:如果在5秒钟之内用户用鼠标点击按钮的次数超过10次,则弹出提示,如果点击速度慢则可以无限制点击次数。主要是不给用户“猛点击”,提供个算法思路也行。 展开
 我来答
翾翳嬿
推荐于2017-11-25 · TA获得超过423个赞
知道小有建树答主
回答量:190
采纳率:66%
帮助的人:257万
展开全部
以下是我写的一个,你可以试试:

<!DOCTYPE>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>RunJS</title>
</head>
<body>
<input value="秒杀" type="button" id="btnTest"/>
<script type="text/javascript">
var btnTest=document.getElementById("btnTest");
var timerId,temp,timerNum;
if(!!btnTest)
{
temp=0,timerNum=0;
btnTest.onclick=function(e)
{
temp++;
if(!timerId)
{
timerId=setInterval(function(){timerNum++;btnTest.value=timerNum+"秒内点 击"+temp+"次";},1000);
setTimeout(function(){if(temp<10){reset();}},6000);
}
else if(temp>9 && timerNum<=5)
{
btnTest.disabled=true;
reset();
alert("您点击的太猛了,会吧电脑累坏的,休息3秒吧!");
setTimeout(function(){btnTest.disabled=false;},3000);
return false;
}
else if(temp<9 && timerNum==5)
{
reset();
}
}
}
var reset=function(){
clearInterval(timerId);
timerId=null;
temp=0;
timerNum=0;
btnTest.value="秒杀";
}
</script>
</body>
</html>
草薙在
2013-02-01 · TA获得超过4795个赞
知道大有可为答主
回答量:6187
采纳率:50%
帮助的人:6266万
展开全部
你可以在document上注册onclick事件,这样页面上所有的click都会捕获。

判断次数你可以建立一个数组,javascript数组有像堆栈一样的方法,pop和shift,你可以以每秒为一个槽位,判断当前点击时刻和上一次点击时刻的时间精确到秒数是否一样,如果一样就在当前槽位上加1,否则就shift一个新的槽位进去,每次判断的时候把所有槽位的数加起来看是否超过10.
本回答被网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
s911415
2013-02-01
知道答主
回答量:18
采纳率:0%
帮助的人:14.9万
展开全部
var md=0,dt=0;
document.onmousedown=function(){
if(new Date().getTime()-dt<5*1000 && md>=10){
alert("不要连续点击!");
dt=new Date().getTime();
md=0;
}else{
md++;
}
dt=new Date().getTime();
}
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
邰箫曲卓
2019-04-29 · TA获得超过1164个赞
知道小有建树答主
回答量:1351
采纳率:100%
帮助的人:7.5万
展开全部
var md=0,dt=0;<br>document.onmousedown=function(){<br> if(new Date().getTime()-dt<5*1000 && md>=10){<br> alert("不要连续点击!");<br> dt=new Date().getTime();<br> md=0;<br> }else{<br> md++;<br> }<br> dt=new Date().getTime();<br>}
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(2)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式