這個問題一直是初學者的困惑。先明白js能放在HTML的那個位置,分別是head和body。大部分人都是放到head裡面的。我學的時候也是稀裡糊塗的跟著放到head的裡面,也不知道為什麼?今天看說說,放到這兩個地方的差別:
先看一段html程式碼:
<html> <head> <title> New Document </title> <meta http-equiv="content-type" content="text/html;charset=utf-8"> <script type="text/javascript" src="test.js"></script> </head> <body> <div id="target"> </div> <button id="btn">按钮</button> </body> </html>
var test = function(){ var span = document.createElement("span"); span.innerHTML="添加"; document.getElementById("target").appendChild(span); } document.getElementById("btn").onclick=test;
如果這段程式碼放到head裡面就不能運作。為什麼?
這就要說一下HTML的運行順序了,應該要確切點說不是HTML的運行順序,是js的運行順序。 HTML從上運行到的時候進入test.js檔案。前面的不會運行,也就是被function包起來的不會被運行,這個時候就執行最後一句。去頁面中取元素Id為btn的元素。但這個時候,HTML頁面並沒有載入完。肯定取不到id為btn的元素。會報錯。這時候有人說可以改成下面的程式碼:
document.body.onload = function(){ document.getElementById("btn").onclick=test; };
但是這樣寫還不如,寫到
以上是Js放到HTML檔案中的位置差異說明的詳細內容。更多資訊請關注PHP中文網其他相關文章!