1

在这个例子中,'div' 元素的第一个子节点是什么?

我认为这将是第一个“p”元素。不过,这似乎是另一回事。

<!DOCTYPE html>
<html>
<body>

<div id="myDiv">
<p>my first paragraph</p>
<p>my second paragraph</p>
</div>

<p id="demo1"></p>
<p id="demo2"></p>


<script>
document.getElementById("demo1").innerHTML = document.getElementById("myDiv").childNodes[0];

document.getElementById("demo2").innerHTML = document.getElementById("myDiv").childNodes[1].childNodes[0].nodeValue;


</script>

</body>
</html>


my first paragraph

my second paragraph

[object Text]

my first paragraph
4

1 回答 1

1

由于父项的开头有空格,因此textNode以空格作为内容。您可以检查nodeType属性(3表示文本节点)以检查节点类型。

console.log(document.getElementById("myDiv").childNodes[0].nodeType)
<div id="myDiv">
  <p>my first paragraph</p>
  <p>my second paragraph</p>
</div>


要仅获取子元素,请使用children属性。

document.getElementById("myDiv").children[0].textContent;

console.log(document.getElementById("myDiv").children[0].textContent)
<div id="myDiv">
  <p>my first paragraph</p>
  <p>my second paragraph</p>
</div>

于 2019-05-01T14:51:00.933 回答