【发布时间】:2015-11-04 18:31:53
【问题描述】:
我有一个包含<div id="main"> 的html 文档。在这个div 内部可能有多个级别的节点,没有精确的结构,因为是创建文档内容的用户。
我想使用 JavaScript 函数返回div id="main" 中的所有节点。任何标签都是,考虑到可能有不同级别的孩子。
例如,如果我有这个文件:
...
<div id="main">
<h1>bla bla</h1>
<p>
<b>fruits</b> apple<i>text</i>.
<img src="..">image</img>
</p>
<div>
<p></p>
<p></p>
</div>
<p>..</p>
</div>
...
函数getNodes将返回一个对象节点数组(我不知道如何表示,所以我列出它们):
[h1, #text (= bla bla), p, b, #text (= fruits), #text (= _apple), i, #text (= text), img, #text (= image), div, p, p, p, #text (= ..)]
正如我们从示例中看到的,您必须返回所有节点,甚至是叶节点(即#text 节点)。
现在我有这个函数可以返回除叶子之外的所有节点:
function getNodes() {
var all = document.querySelectorAll("#main *");
for (var elem = 0; elem < all.length; elem++) {
//do something..
}
}
其实上面例子中应用的这个特性返回:
[H1, P, B, I, IMG, DIV, P, P, P]
没有#text 节点。 另外,如果该方法以这种方式返回的文本元素:
all[elem].children.length
我知道(我在<p>fruits</p> 上测试过)<p> 是一个 leaf 节点。
但是如果我构建 DOM 树,很明显它不是叶节点,在这个例子中叶节点是 #text...
谢谢
【问题讨论】:
标签: javascript html tree