在 XML DOM 中,遍历(Traversal)是指通过节点之间的关系沿着文档树导航,访问和操作节点的过程。遍历可以沿着父子关系、兄弟关系或其他关系进行。以下是一些常见的 DOM 遍历方法:

1. 遍历子节点(Child Nodes):

通过 childNodes 属性可以获取节点的所有子节点。这个属性返回一个 NodeList 对象,可以通过索引访问其中的子节点。
var parentElement = document.getElementById("parent");
var childNodes = parentElement.childNodes;

for (var i = 0; i < childNodes.length; i++) {
  var childNode = childNodes[i];
  // 对每个子节点执行操作
  console.log(childNode.nodeName);
}

2. 遍历父节点(Parent Node):

通过 parentNode 属性可以获取节点的父节点。
var childElement = document.getElementById("child");
var parentNode = childElement.parentNode;

// 对父节点执行操作
console.log(parentNode.nodeName);

3. 遍历兄弟节点(Siblings):

通过 nextSibling 和 previousSibling 属性可以获取节点的下一个兄弟节点和前一个兄弟节点。
var targetElement = document.getElementById("target");
var nextSibling = targetElement.nextSibling;
var previousSibling = targetElement.previousSibling;

// 对兄弟节点执行操作
console.log("Next Sibling:", nextSibling);
console.log("Previous Sibling:", previousSibling);

4. 遍历第一个和最后一个子节点:

通过 firstChild 和 lastChild 属性可以获取节点的第一个子节点和最后一个子节点。
var parentElement = document.getElementById("parent");
var firstChild = parentElement.firstChild;
var lastChild = parentElement.lastChild;

// 对第一个和最后一个子节点执行操作
console.log("First Child:", firstChild);
console.log("Last Child:", lastChild);

5. 遍历元素节点:

通过 getElementsByTagName 或 querySelectorAll 方法可以获取匹配某个标签名的元素节点集合,然后进行遍历。
var paragraphs = document.getElementsByTagName("p");

for (var i = 0; i < paragraphs.length; i++) {
  var paragraph = paragraphs[i];
  // 对每个段落执行操作
  console.log(paragraph.textContent);
}

示例:

考虑以下 HTML 片段:
<div id="parent">
  <p>Paragraph 1</p>
  <p>Paragraph 2</p>
  <p>Paragraph 3</p>
</div>

<p id="target">Target Paragraph</p>

对应的 JavaScript 代码:
// 遍历子节点
var parentElement = document.getElementById("parent");
var childNodes = parentElement.childNodes;

console.log("Child Nodes:");
for (var i = 0; i < childNodes.length; i++) {
  var childNode = childNodes[i];
  console.log(childNode.nodeName);
}

// 遍历父节点
var childElement = document.getElementById("target");
var parentNode = childElement.parentNode;

console.log("Parent Node:");
console.log(parentNode.nodeName);

// 遍历兄弟节点
var nextSibling = childElement.nextSibling;
var previousSibling = childElement.previousSibling;

console.log("Next Sibling:", nextSibling);
console.log("Previous Sibling:", previousSibling);

// 遍历第一个和最后一个子节点
var firstChild = parentElement.firstChild;
var lastChild = parentElement.lastChild;

console.log("First Child:", firstChild.nodeName);
console.log("Last Child:", lastChild.nodeName);

// 遍历元素节点
var paragraphs = document.getElementsByTagName("p");

console.log("Paragraphs:");
for (var i = 0; i < paragraphs.length; i++) {
  var paragraph = paragraphs[i];
  console.log(paragraph.textContent);
}

这个示例演示了如何使用不同的 DOM 遍历方法,通过访问子节点、父节点、兄弟节点和元素节点来操作文档的结构。这些遍历方法是在动态操作文档中非常有用的工具。


转载请注明出处:http://www.pingtaimeng.com/article/detail/14565/XML DOM