JavaScript操作DOM元素的childNodes和children區別
來源:易賢網 閱讀:1485 次 日期:2015-04-02 16:22:36
溫馨提示:易賢網小編為您整理了“JavaScript操作DOM元素的childNodes和children區別”,方便廣大網友查閱!

對于DOM元素,children是指DOM Object類型的子對象,不包括tag之間隱形存在的TextNode,而childNodes包括tag之間隱形存在的TextNode對象。

具體看一下針對children和childNodes在chrome環境下的測試:

<!DOCTYPE html>

<html>

<head>

<meta charset="UTF-8">

<title>Insert title here</title>

</head>

<body>

<div id="div1" class="div">

<span id="s1" class="sp" lang="zh-cn">

</span>

</div>

</body>

<script type="text/javascript">

function test() {

var o = document.getElementById("div1");

var child = o.children;

console.log("div1.children運行結果:");

for(i = 0; i < child.length; i++){

console.log(child[i].tagName);

}

console.log("");

child = o.childNodes;

console.log("div1.childNodes運行結果:");

for(i = 0; i < child.length; i++){

console.log(child[i].tagName);

}

}

test();

</script>

</html>

測試結果如下:

div1.children運行結果:

SPAN

div1.childNodes運行結果:

undefined

SPAN

undefined

上面childNodes集合的結果中有兩個undefined節點,這連個就是nodeType=3的TextNode。

如果把HTML代碼寫成如下樣式,那么children和childNodes的結果就沒有差別了。

<body>

<div id="div1" class="div"><span id="s1" class="sp" lang="zh-cn"></span></div>

</body>

對document、head、body及div等HTML元素實測未發現有其他差異

更多信息請查看IT技術專欄

更多信息請查看腳本欄目
由于各方面情況的不斷調整與變化,易賢網提供的所有考試信息和咨詢回復僅供參考,敬請考生以權威部門公布的正式信息和咨詢為準!

2026國考·省考課程試聽報名

  • 報班類型
  • 姓名
  • 手機號
  • 驗證碼
關于我們 | 聯系我們 | 人才招聘 | 網站聲明 | 網站幫助 | 非正式的簡要咨詢 | 簡要咨詢須知 | 新媒體/短視頻平臺 | 手機站點 | 投訴建議
工業和信息化部備案號:滇ICP備2023014141號-1 云南省教育廳備案號:云教ICP備0901021 滇公網安備53010202001879號 人力資源服務許可證:(云)人服證字(2023)第0102001523號
云南網警備案專用圖標
聯系電話:0871-65099533/13759567129 獲取招聘考試信息及咨詢關注公眾號:hfpxwx
咨詢QQ:1093837350(9:00—18:00)版權所有:易賢網
云南網警報警專用圖標
未满十八18勿进黄网站免费看