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

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

setInterval 不更新變量

setInterval 不更新變量

梵蒂岡之花 2023-10-04 15:19:37
當(dāng)我運行代碼時,它僅在我創(chuàng)建的初始變量“2000”處間隔。當(dāng)我單擊按鈕時,它不會將間隔更改為“50”。有誰知道為什么?<html>    <body>        <h1 id="pressme"> Press me! </h1>    </body>    <script>    amount = 2000;    var i = 1;    document.getElementById("pressme").onclick = function() {        amount = 50;    }        function doSomething() {            i++;            console.log("I did something! " + i);        }        setInterval(doSomething, amount)    </script></html>這不是 OG 代碼,而是它的簡化版本。
查看完整描述

2 回答

?
青春有我

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

您應(yīng)該將 setInterval 與clearInterval 一起使用。


<html>

    <body>

        <h1 id="pressme"> Press me! </h1>

    </body>


    <script>

        amount = 2000;

        var i = 1;

        var handler

        document.getElementById("pressme").onclick = function() {

            amount = 50;

            clearInterval(handler);

            handler = setInterval(doSomething, amount);

        }

        function doSomething() {

            i++;

            console.log("I did something! " + i);

        }

        handler = setInterval(doSomething, amount);

    </script>

因此,當(dāng)單擊按鈕時,您應(yīng)該刪除原始的 setInterval 處理程序并重新創(chuàng)建它。


查看完整回答
反對 回復(fù) 2023-10-04
?
慕的地10843

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

間隔已經(jīng)設(shè)置為 2 秒,如果之后更改變量,則不會有任何影響。


我建議你這樣做:


let amount = 2000;

let interval = setInterval(doSomething, amount);


var i = 1;

document.getElementById("pressme").onclick = function () {

    clearInterval(interval);

    amount = 50;

    setInterval(doSomething, amount);

}

function doSomething() {

    i++;

    console.log("I did something! " + i);

}


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

添加回答

舉報

0/150
提交
取消
微信客服

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

幫助反饋 APP下載

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

公眾號

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