HTML DOM 导航

通过 HTML DOM,您能够使用节点关系在节点树中导航。


HTML DOM 节点列表

getElementsByTagName() 方法返回节点列表。节点列表是一个节点数组。

下面的代码选取文档中的所有 <p> 节点:

  1. var x=document.getElementsByTagName("p");

可以通过下标号访问这些节点。如需访问第二个 <p>,您可以这么写:

  1. <!DOCTYPE html>
  2. <html>
  3. <body>
  4. <p>Hello World!</p>
  5. <p>DOM 很有用!</p>
  6. <script>
  7. x=document.getElementsByTagName("p");
  8. document.write("第二段的 innerHTML 是: " + x[1].innerHTML);
  9. </script>
  10. </body>
  11. </html>

注释:下标号从 0 开始。


HTML DOM 节点列表长度

length 属性定义节点列表中节点的数量。

您可以使用 length 属性来循环节点列表:

  1. <!DOCTYPE html>
  2. <html>
  3. <body>
  4. <p>Hello World!</p>
  5. <p>DOM 很有用!</p>
  6. <p>本例演示 <b>length</b> 属性。</p>
  7. <script>
  8. x=document.getElementsByTagName("p");
  9. for (i=0;i<x.length;i++)
  10. {
  11. document.write(x[i].innerHTML);
  12. document.write("<br>");
  13. }
  14. </script>
  15. </body>
  16. </html>
例子解释:

获取所有 <p> 元素节点

输出每个 <p> 元素的文本节点的值


导航节点关系

您能够使用三个节点属性:parentNodefirstChild 以及 lastChild ,在文档结构中进行导航。

请看下面的 HTML 片段:

  1. <html>
  2. <body>
  3. <p>Hello World!</p>
  4. <div>
  5. <p>DOM 很有用!</p>
  6. <p>本例演示节点关系。</p>
  7. </div>
  8. </body>
  9. </html>
  • 首个 <p> 元素是 <body> 元素的首个子元素(firstChild)
  • <div> 元素是 <body> 元素的最后一个子元素(lastChild)
  • <body> 元素是首个 <p> 元素和 <div> 元素的父节点(parentNode)

firstChild 属性可用于访问元素的文本:

  1. <!DOCTYPE html>
  2. <html>
  3. <body>
  4. <p id="intro">Hello World!</p>
  5. <script>
  6. x=document.getElementById("intro");
  7. document.write(x.firstChild.nodeValue);
  8. </script>
  9. </body>
  10. </html>

DOM 根节点

这里有两个特殊的属性,可以访问全部文档:

  • document.documentElement - 全部文档
  • document.body - 文档的主体
实例
  1. <!DOCTYPE html>
  2. <html>
  3. <body>
  4. <p>Hello World!</p>
  5. <div>
  6. <p>DOM 很有用!</p>
  7. <p>本例演示 <b>document.body</b> 属性。</p>
  8. </div>
  9. <script>
  10. alert(document.body.innerHTML);
  11. </script>
  12. </body>
  13. </html>

childNodes 和 nodeValue

除了 innerHTML 属性,您也可以使用 childNodesnodeValue 属性来获取元素的内容。

下面的代码获取 id="intro" 的 <p> 元素的值:

  1. <!DOCTYPE html>
  2. <html>
  3. <body>
  4. <p id="intro">Hello World!</p>
  5. <script>
  6. txt=document.getElementById("intro").childNodes[0].nodeValue;
  7. document.write(txt);
  8. </script>
  9. </body>
  10. </html>

在上面的例子中,getElementById 是一个方法,而 childNodesnodeValue 是属性。

在本教程中,我们将使用 innerHTML 属性。不过,学习上面的方法有助于对 DOM 树结构和导航的理解。

分类导航