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

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

如何在 React.js 中每 5 秒生成一個隨機數?

如何在 React.js 中每 5 秒生成一個隨機數?

溫溫醬 2023-06-15 17:42:06
我知道這個問題已經被問到并得到了回答,但我似乎無法獲得預期的輸出。let ranNum = 0;setTimeout(function(){     ranNum = Math.floor((Math.random()*100)+1); }, 5000);當我運行這個程序時,我的 chrome 瀏覽器不斷生成隨機數,直到我停止程序。我也用 setInterval 試過這個。我想要發生的是每 5 秒生成一個隨機數并將其添加到我的代碼中的另一個變量。(所以這個變量應該每五秒顯示一個不同的數字)。我正在我的客戶端 - React.js 中執行此操作,并且想知道是否有另一種方法可以通過 React 執行此操作。感謝你的幫助!
查看完整描述

1 回答

?
RISEBY

TA貢獻1856條經驗 獲得超5個贊

您可以使用useEffect鉤子來設置間隔并更新狀態,然后顯示狀態


const RandomNumber = () => {

  const [number, setNumber] = React.useState(0);

  

  // add side effect to component

  React.useEffect(() => {

    // create interval

    const interval = setInterval(

      // set number every 5s

      () => setNumber(Math.floor(Math.random() * 100 + 1)),

      5000

    );


    // clean up interval on unmount

    return () => {

      clearInterval(interval);

    };

  }, []);


  return <p>{number}</p>;

};


ReactDOM.render(<RandomNumber />, document.getElementById("root"));

<script src="https://unpkg.com/react@17/umd/react.production.min.js" crossorigin></script>

<script src="https://unpkg.com/react-dom@17/umd/react-dom.production.min.js" crossorigin></script>

<div id="root"></div>


查看完整回答
反對 回復 2023-06-15
  • 1 回答
  • 0 關注
  • 137 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

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

幫助反饋 APP下載

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

公眾號

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