第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

在 JavaScript 中,我們?nèi)绾畏乐乖谔囟〞r間內(nèi)一次又一次點擊按鈕?

在 JavaScript 中,我們?nèi)绾畏乐乖谔囟〞r間內(nèi)一次又一次點擊按鈕?

慕娘9325324 2023-12-04 14:41:23
因此,在代碼中,按下按鈕將使紅色框產(chǎn)生動畫效果。單擊該按鈕會將其沿對角線移動。但是,如果我們在動畫發(fā)生時再次單擊該按鈕,或者多次單擊該按鈕,則會產(chǎn)生閃爍效果。我們該如何解決這個問題?<!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條經(jīng)驗 獲得超3個贊

您需要在動畫進行時設(shè)置一個標志,并且在動畫仍在進行時不要執(zhí)行該函數(shù)


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>


查看完整回答
反對 回復(fù) 2023-12-04
?
慕桂英546537

TA貢獻1848條經(jīng)驗 獲得超10個贊

我能想到的有兩種方法:

第一個是禁用按鈕,并創(chuàng)建一個計時器(setTimeout)來重新啟用它

第二個是保存第二次單擊的時間,并檢查您的單擊處理程序是否很快發(fā)生另一次單擊(使用保存的第二次單擊時間)。


查看完整回答
反對 回復(fù) 2023-12-04
  • 2 回答
  • 0 關(guān)注
  • 166 瀏覽

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動學習伙伴

公眾號

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號