簡體   English   中英

單擊后如何在 React js 中禁用按鈕 20 秒

[英]How I can disable a button in React js for 20 seconds after click

我需要禁用一個按鈕 20 秒。 當我點擊並獲得當前時間時,我需要在 20 秒后可以進行下一次點擊。 我嘗試了 useEffect,但它對我不起作用。

function App() {
const [time, setTime] = useState([]);
const [endTime, setEndTime] = useState([]);

const startWork = (e) => {
    e.preventDefault();
    const StartTime = {
        thisTime: new Date().toLocaleString(),
    };

    setTime(StartTime);
};

const finishWork = (e) => {
    e.preventDefault();
    const StopTime = {
        endTime: new Date().toLocaleString(),
    };

    setEndTime(StopTime);
};

return (
    <div className='App'>
        <div className='startWork'>
            <h1>Start: {time.thisTime}</h1>
            <button type='button' onClick={startWork} disabled={time.thisTime}>
                Start work
            </button>
        </div>
        <div className='finishWork' />
        <h1>Finish: {endTime.endTime}</h1>
        <button type='button' onClick={finishWork} disabled={endTime.endTime}>
            Finish work
        </button>
    </div>
);

}

只需在您的 onClick 處理程序中使用 setTimeout

const [disabled, setDisabled] = useState(false);
...
onClick={() => {e.preventDefault();
    setDisabled(true);
    setTimeout(() => {
        setDisabled(false);
    }, 20000)}
};
...
<button disabled={disabled} />

嘗試使用 Vanilla JavaScript 的這個概念! 我已經實施了3sec但同樣可以實施20sec

 let button = document.getElementById('btn'); const wait_20sec = () =>{ setTimeout(function(){ button.setAttribute('disabled', true); }, 3000);//3000ms = 3sec } button.addEventListener('click',wait_20sec)
 <button id="btn">Click Me</button>

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM