亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

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

彈出窗口 - 一個接一個

彈出窗口 - 一個接一個

慕田峪7331174 2023-09-18 10:30:30
我想向用戶彈出窗口顯示 2 秒,一個接著一個(可以是任何數字,假設 17)。任何想法如何做到這一點?function sleep(miliseconds) {  var currentTime = new Date().getTime();  while (currentTime + miliseconds >= new Date().getTime()) {  }}/*First option*/ function printFailureMessages (failureMessages){  failureMessages.forEach(message => {      document.getElementById("myPopup").innerHTML = message;      document.getElementById("myPopup").classList.toggle("show");      sleep(1500);      document.getElementById("myPopup").classList.toggle("show");  });}/*Second option*/function printFailureMessages (failureMessages){  failureMessages.forEach(message => {      document.getElementById("myPopup").innerHTML = message;      document.getElementById("myPopup").classList.toggle("show");      setTimeout(function(){        document.getElementById("myPopup").classList.toggle("show");      },1500);  });}當 failureMessages 大小為 1 時效果很好...順便說一句 - 我嘗試了 setTimeOut 的更多變體,但不成功..
查看完整描述

1 回答

?
飲歌長嘯

TA貢獻1951條經驗 獲得超3個贊

您可以嘗試使用async/await這樣的方法:


// Return a promise that resolves after "miliseconds" milliseconds

function sleep(miliseconds) {

   return new Promise(res => setTimeout(res, miliseconds));

}


// Make this function async function

async function printFailureMessages(failureMessages) {

   for (var i = 0; i < failureMessages.length; i++) {

      document.getElementById("myPopup").innerHTML = failureMessages[i];

      document.getElementById("myPopup").classList.toggle("show");

      await sleep(1500); // wait for this promise to finish

      document.getElementById("myPopup").classList.toggle("show");

   }

}


printFailureMessages(['Hello', 'World']);


查看完整回答
反對 回復 2023-09-18
  • 1 回答
  • 0 關注
  • 100 瀏覽

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號