为了账号安全,请及时绑定邮箱和手机立即绑定

在 JavaScript 中,我们如何防止在特定时间内一次又一次点击按钮?

在 JavaScript 中,我们如何防止在特定时间内一次又一次点击按钮?

慕娘9325324 2023-12-04 14:41:23
因此,在代码中,按下按钮将使红色框产生动画效果。单击该按钮会将其沿对角线移动。但是,如果我们在动画发生时再次单击该按钮,或者多次单击该按钮,则会产生闪烁效果。我们该如何解决这个问题?<!DOCTYPE html><html><style>#container {  width: 400px;  height: 400px;  position: relative;  background: yellow;}#animate {  width: 50px;  height: 50px;  position: absolute;  background-color: red;}</style><body><p><button onclick="myMove()">Click Me</button></p> <div id ="container">  <div id ="animate"></div></div><script>function myMove() {  var elem = document.getElementById("animate");     var pos = 0;  var id = setInterval(frame, 5);  function frame() {    if (pos == 350) {      clearInterval(id);    } else {      pos++;       elem.style.top = pos + "px";       elem.style.left = pos + "px";     }  }}</script></body></html>
查看完整描述

2 回答

?
慕森王

TA贡献1777条经验 获得超3个赞

您需要在动画进行时设置一个标志,并且在动画仍在进行时不要执行该函数


var animationInProgress = false;


function myMove() {

  if (animationInProgress) {

    return;

  }


  var elem = document.getElementById("animate");

  var pos = 0;

  var id = setInterval(frame, 5);

  animationInProgress = true;


  function frame() {

    if (pos == 350) {

      animationInProgress = false;

      clearInterval(id);

    } else {

      pos++;

      elem.style.top = pos + "px";

      elem.style.left = pos + "px";

    }

  }

}

#container {

  width: 400px;

  height: 400px;

  position: relative;

  background: yellow;

}


#animate {

  width: 50px;

  height: 50px;

  position: absolute;

  background-color: red;

}

<p><button onclick="myMove()">Click Me</button></p>


<div id="container">

  <div id="animate"></div>

</div>


查看完整回答
反对 回复 2023-12-04
?
慕桂英546537

TA贡献1848条经验 获得超10个赞

我能想到的有两种方法:

第一个是禁用按钮,并创建一个计时器(setTimeout)来重新启用它

第二个是保存第二次单击的时间,并检查您的单击处理程序是否很快发生另一次单击(使用保存的第二次单击时间)。


查看完整回答
反对 回复 2023-12-04
  • 2 回答
  • 0 关注
  • 104 浏览

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信