- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个 html 文档,其中包含 <div id="main">
。里面这个div
可能是多层节点,没有精确的结构,因为是创建文档内容的用户。我想使用 JavaScript 函数返回 div id="main"
内的所有节点。任何标签都是考虑到可能存在不同级别的 child 。
例如,如果我有这个文档:
...
<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>
是一个叶节点。但如果我构建 DOM 树,很明显这不是叶节点,在本例中叶节点是 #text
...
谢谢
最佳答案
递归到 DOM 的经典案例。
function getDescendants(node, accum) {
var i;
accum = accum || [];
for (i = 0; i < node.childNodes.length; i++) {
accum.push(node.childNodes[i])
getDescendants(node.childNodes[i], accum);
}
return accum;
}
和
getDescendants( document.querySelector("#main") );
关于javascript - 获取某个节点的所有后代节点(也是叶子节点),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33529398/
Infix[]仅适用于第一级: Infix[(c a^b)^d] (* -> (a^b c) ~Power~ d *) 由于我想(不要问为什么)将完整表达式切换为中缀表示法,因此我尝试了以下操作: S
我正在寻找遍历特定元素的叶子的最有效方法。例如: One Two Paragraph Text
我想评估 bool 表达式,例如 a=b & s、>=、{ eval() {} // bool operator()(const var& v) const {
我正在尝试将物联网边缘设备设置为边缘网关。我们不希望我们的叶子/传感器/下游设备直接连接到互联网/云,因此我希望物联网边缘网关(顾名思义)能够桥接下游设备和云/物联网之间的连接中心。但是,我意识到任何
我是一名优秀的程序员,十分优秀!