程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> JAVA編程 >> JAVA綜合教程 >> <script>放在head或者body中出現的問題,headbody

<script>放在head或者body中出現的問題,headbody

編輯:JAVA綜合教程

<script>放在head或者body中出現的問題,headbody


  今天看js高級編程form表單這一章,看著書上的例子敲代碼的時候出現了一點問題,什麼問題先不說,先看這段代碼?

<!DOCTYPE html> <html> <head> <title>Form Fields Example</title> <script type="text/javascript"> var form = document.getElementById("myForm"); console.log(form.elements['color'].length); </script> </head> <body> <form method="post" id="myForm"> <ul> <li><input type="radio" name="color" value="red">Red</li> <li><input type="radio" name="color" value="green">Green</li> <li><input type="radio" name="color" value="blue">Blue</li> </ul> </form> </body> </html> View Code

代碼就是上面這個樣子的,很簡單的一個表單裡面有一組radio標簽,要實現的效果也就是通過表單拿到這一組radio標簽,但是我按照上面的寫法打出來之後控制台卻一直報錯,錯誤信息如下:

意思就是無法讀取null的elements屬性,開始我還以為是我代碼寫錯了,但是仔細檢查之後發現也沒錯,甚至我還以為是form表單沒有寫action屬性這些造成的,但是一一嘗試之後發現還是一直在報相同的錯誤,沒辦法了之後去找這本書的示例代碼,示例代碼如下所示:

<!DOCTYPE html> <html> <head> <title>Form Fields Example</title> </head> <body> <form method="post" id="myForm"> <ul> <li><input type="radio" name="color" value="red">Red</li> <li><input type="radio" name="color" value="green">Green</li> <li><input type="radio" name="color" value="blue">Blue</li> </ul> </form> <script type="text/javascript"> var form = document.getElementById("myForm"); console.log(form.elements['color'].length); </script> </body> </html> View Code

拿到示例代碼之後發現運行完成正確,沒有任何錯誤,當時我就比較郁悶了,兩個代碼幾乎是完全一樣,唯一不一樣的就是<script>標簽的位置不一樣,我按照慣例把<script>標簽寫在了<head>標簽中,示例中是把<script>標簽放在了<body>中,然後我就把我的代碼也放在<body>中,然後就沒有繼續出錯了,我就感覺很奇怪,因為我記得<script>標簽是可以放在頁面上的任何位置的,但是為什麼放在不同的地方就不一樣了呢?為了驗證我的猜想,我做了一下幾個實驗:

<!DOCTYPE html>
<html>
	<head>
		<meta charset="UTF-8">
		<script>
			 console.log(111);	//111	
			var colors1 = document.getElementsByName("color");
			console.log('--------1----------'+colors1.length);//--------1----------0
			var form1 = document.getElementById("myForm");
			console.log('-----1-------------'+form1);//-----1-------------null
			var sizeRadio1 = document.getElementsByName("size");
			console.log('-----size1------'+sizeRadio1.length);//-----size1------0
		</script>
	</head>
	<body>
		<ul>
			<li>
				<input type="radio" name="size" value="1" />
				<input type="radio" name="size" value="2" />
				<input type="radio" name="size" value="3" />
				<input type="radio" name="size" value="4" />
			</li>
		</ul>
		
		<form method="post"  id="myForm">
	        <ul>
	            <li><input type="radio" name="color" value="red">Red</li>
	            <li><input type="radio" name="color" value="green">Green</li>
	            <li><input type="radio" name="color" value="blue">Blue</li>
	        </ul>
	    </form>
	</body>
	<script>
			console.log(222);	
			var colors2 = document.getElementsByName("color");
			console.log('-------2----------'+colors2.length);//-------2----------3
			 var form2 = document.getElementById("myForm");
            console.log('------------form2----------------------'+form2.elements.length);//------------form2----------------------3
            var sizeRadio2 = document.getElementsByName("size");
			console.log('-----size2------'+sizeRadio2.length);//-----size2------4
	</script>
</html>

  通過上面的代碼,我發現了這麼個情況,只要是沒有操作<body>中標簽的script代碼放在那裡都無所謂,只不過是加載順序不一樣罷了,就行打印111和打印222一樣,先打印出來了在head中的111,然後才打印出來了再body中的222,但是在需要操作body中的元素時,在head標簽中的script代碼就會出問題,就是找不到需要操作的元素,經過我的實驗之後我得出的一個結論是:如果需要在script中操作body中的元素,那麼必須在要操作的元素加載完成之後才可以,也就是說要把操作元素的js代碼放在元素之後。

  後來我在網上查了一下html頁面上關於js以及標簽的加載順序,跟我的猜想是一樣的,html是從上到下進行加載的,遇到使用連接方式加載的js或者css就發送request請求加載,如果是直接寫的代碼,那麼就直接初始化,如果是函數那麼就直接初始化,在觸發時直接執行函數,如果在head中操作body中的元素,那麼就會出現找不到的情況,因為此時body中的元素還沒有加載完成。

    我的理解暫時就是這個樣子了,如果有說的不對的地方歡迎大家指正。

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved