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

来源:http://www.cnblogs.com/liaidai/archive/2016/03/18/5292277.html
-Advertisement-
Play Games

今天看js高級編程form表單這一章,看著書上的例子敲代碼的時候出現了一點問題,什麼問題先不說,先看這段代碼? 代碼就是上面這個樣子的,很簡單的一個表單裡面有一組radio標簽,要實現的效果也就是通過表單拿到這一組radio標簽,但是我按照上面的寫法打出來之後控制台卻一直報錯,錯誤信息如下: 意思就


  今天看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中的元素還沒有載入完成。

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


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 在分散式環境,管理Session通常使用下麵三種方式: 一、Session Replication 方式管理 (即session複製) 簡介:將一臺機器上的Session數據廣播複製到集群中其餘機器上 使用場景:機器較少,網路流量較小 優點:實現簡單、配置較少、當網路中有機器Down掉時不影響用戶訪
  • 1.下載Java開發環境工具包JDK,下載地址:http://www.oracle.com/technetwork/java/javase/downloads/index.html 下載後,雙擊jdk應用程式,根據提示完成安裝,安裝過程中可以自定義安裝目錄等信息,這裡我選擇安裝目錄為:C:\Prog
  • 下麵以windows平臺和Aptana Studio為例,介紹XDdebug的使用。 1)下載php的XDebug擴展.dll文件,官網下載地址是https://xdebug.org/download.php,可以根據實際php運行系統架構、VC版本和線程安全情況下載。 2)將下載的.dll文件複製
  • 前不久,有人來我們公司面試,我們的經理問道了這個問題,我也是一知半解,所以就去百度了一番。 其實區別很簡單的,舉個例子大家就會明白的。寫一句SQL-例如:select * from user_role where user_code = "100"; 這句話而言,需要寫成 select * from
  • 抽象的定義:抽象是把多個事物的共性的內容抽取出來,本質就是把我們關註的內容抽取出來。(比如:寶馬,賓士都屬於汽車,汽車是抽象出來的概念); 抽象類:Java中可以定義沒有方法體的方法,該方法由其子類來具體的實現。該沒有方法體的方法我們稱之為抽象方法,含有抽象方法的類我們稱之為抽象類; 抽象方法特點:
  • 1.標識符包、類、方法、參數和變數的名稱。大小寫字母、數字、_和$符號的組合,不以數字開始,不能使關鍵字,不能包括分隔符和換行。(嚴格區分大小寫,最大長度255個字元) 2.字面量 某種類型的值(具體的值) 3.註釋不能執行的文字,多用於解釋,有單行註釋//...,多行註釋/*...*/和文檔註釋/
  • ThinkPHP目錄如下,Application顧名思義就是應用的意思(我們的代碼放在這裡),Public就是公共文件的意思(主要放JS CSS 等前端資源文件),ThinkPHP文件是框架的核心包(我們一般不要操作它)。意思就是我們搞後臺的人員寫代碼應該寫在Application的目錄下 第二步,
  • 剛開始學習python變成, 這勉強算是第一個博客吧, 主要記錄了一下 字元串 中的方法, 不太準確,或者是錯誤的地方, 請大家指點 str1 = "GooGle" str2 = "baidu" #print("Google的類型是 %s \n" % type(str1)) #Google的類型是 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...