為什么一個無窮循環,一個只運行一次?
為什么
當按鈕start被點擊時,setTimeout()調用函數,在5秒后彈出一個提示框?? 只運行一次?
<!DOCTYPE HTML>
<html>
<head>
<script type="text/javascript">
function tinfo(){
?var t=setTimeout("alert('Hello!')",5000);
}
</script>
</head>
<body>
<form>
?<input type="button" value="start" onClick="tinfo()">
</form>
</body>
</html>
而這個代碼就創建一個運行于無窮循環中的計數器,而不是只運行一次?
<!DOCTYPE HTML>
<html>
<head>
<script type="text/javascript">
var num=0;
function numCount(){
document.getElementById('txt').value=num;
num=num+1;
setTimeout("numCount()",1000);
}
</script>
</head>
<body>
<form>
<input type="text" id="txt" />
<input type="button" value="Start" onClick="numCount()" />
</form>
</body>
</html>
2016-04-13
下面這個函數,在函數里面調用了自己,相當于運行setTimeout("numCount()",1000);的時候,又將nunCount()重新運行了一次……