It is preferable to use setTimeout. But this is due to browser code scheduling.
function simulateComplexOperation(sleepDuration) {
var now = new Date().getTime();
while (new Date().getTime() < now + sleepDuration) { }
}
function testFunction() {
document.getElementById('panel1').style.display = 'none';
console.log('before');
setTimeout(() => {
console.log('after');
}, 2000);
}
<div id='panel1'>
text to hidden
</div>
<button onclick="testFunction()">Hide</button>
Run codeHide result source
share