我如何在点击后禁用React js中的按钮20秒



我需要禁用一个按钮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} />

尝试使用香草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>

相关内容

  • 没有找到相关文章

最新更新