setTimeout 跟addEventListener問題
問題描述
這是放在菜鳥上寫的代碼 ;
setTimeout 無論設置多長時間 ,innerHtml都是直接出現最終結果;
這是為啥呢
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>菜鳥教程(runoob.com)</title>
</head>
<body>
文檔添加 onmousemove 事件句柄,當在文檔中移動鼠標時會顯示隨機數。
點擊按鈕移除事件句柄。
<button id='demo1'>點我</button>
<p id="demo">
<script>
document.getElementById("demo1").addEventListener("click", myFunction);
var time = 5;
function myFunction() {
document.getElementById("demo").innerHTML = time;
removeHandler(time);
}
function removeHandler(i) {
i--;
document.getElementById("demo").innerHTML = i;
setTimeout(removeHandler(i),1000);
}
</script>
</body>
</html>
問題解答
回答1:setTime()的回調函數是異步執行,只有主調用棧清空才會從任務隊列進入調用棧,所以就會出現你說的這種情況
相關文章:
1. 如何解決docker宿主機無法訪問容器中的服務?2. javascript - Web微信聊天輸入框解決方案3. angular.js - 輸入郵箱地址之后, 如何使其自動在末尾添加分號?4. angular.js - $stateChangeSuccess事件在狀態跳轉的時候不執行?5. javascript - 如何使用nodejs 將.html 文件轉化成canvas6. python - Scrapy存在內存泄漏的問題。7. 如何用筆記本上的apache做微信開發的服務器8. javascript - 螞蟻金服里的react Modal方法,是怎么把元素插入到頁面最后的9. android - rxjava merge 返回Object對象數據如何緩存10. CSS3 畫如下圖形
