可運行代碼
<!DOCTYPE html>
<html>
?<head>
? <title>瀏覽器對象</title>?
? <meta http-equiv="Content-Type" content="text/html; charset=gkb"/>??
?</head>
?<body>
? <!--先編寫好網頁布局-->
? <strong>操作成功</strong>
? <br>
?<nobr> <span id='time'>5</span> </nobr> <span>秒后回到主頁</span>
?<a href='javascript:back()'>返回</a>
?
? <script type="text/javascript">?
?
?? //獲取顯示秒數的元素,通過定時器來更改秒數。
?? var time=document.getElementById('time').innerHTML;
?? setTimeout("changeTime()",1000);
?? function changeTime(){
?????? if(time==0){
?????????? back();
?????? }
?????? time--;
?????? document.getElementById('time').innerHTML=time;
?????? setTimeout("changeTime()",1000);
?? }
??
?? //通過window的location和history對象來控制網頁的跳轉。
?? function back(){
?????? clearTimeout();
?????? window.history.back();
?? }
??
?</script>
</body>
</html>
2018-08-18
把你的代碼敲進去試了試??!找到原因啦!
應該只在函數外使用setInterval("changeTime()",1000);而不是在函數外使用setTimeout("changeTime()",1000);
因為使用setTimeout只會延遲一次,即只能從5數到4。
另外函數內不需要寫計時函數。
2018-08-18
隔熱板認為setTimeout("changeTime()",1000);這句話應該放在外面。
2018-08-18
<meta charset="utf-8"> 試試,如果是js的話,打開調試器,看看報錯,是什么原因
你的這個原因可能還是函數聲明和調用順序的問題
我建議你,
先聲明,后調用。把第一個settimeout放到倒計時函數的后面。因為,HTML頁面是按照從上到下的順序解析文檔的。你的settimeout寫在前面,而你調用的函數在它調用前根本沒有聲明,如果你打開調試器,因該會報錯,changeTime is undefined。
個人意見試試看