我们开发时有一个需求,让我几乎崩溃。
需求总结后就是:
指定body节点下的任意元素节点,算出它是body节点的第几个儿子的,第几个孙子。这个关系可以很长。比如某些很深的元素节点,可能结论是:某元素节点是body节点的第2个儿子的第3个儿子的第1个儿子的第9个儿子。
(PS:textNode要跳过,只计算elementNode)
我实在搞不定了,搜资料也没找到对口的,求大神帮忙,分享一些资料也好啊。
我们开发时有一个需求,让我几乎崩溃。
需求总结后就是:
指定body节点下的任意元素节点,算出它是body节点的第几个儿子的,第几个孙子。这个关系可以很长。比如某些很深的元素节点,可能结论是:某元素节点是body节点的第2个儿子的第3个儿子的第1个儿子的第9个儿子。
(PS:textNode要跳过,只计算elementNode)
我实在搞不定了,搜资料也没找到对口的,求大神帮忙,分享一些资料也好啊。
如果用 jQuery 还是比较好处理的(不过这种处理性能肯定不会好)
function findIndexes(jo) {
var parents = jo.parentsUntil("body");
return parents.map(function() {
return $(this).index();
}).toArray().reverse();
}
这个需求我觉得从安置dom节点的时候就应该考虑到,比如说dom节点与一个数据结构相对应,或者对dom节点做hash(没错就是Vitrual DOM的思路)
不然最优的方案只能是逆向宽搜(通过父节点遍历到目前是第几个,如果父节点不是body就继续这步骤),不过,读取DOM节点的代价也是高昂的不亚于操作DOM节点,适用于DOM数量级较小的页面
如果上了React等,那可以简化一点,其实和第一个数据相同
13 回答12.7k 阅读
7 回答1.8k 阅读
5 回答1.3k 阅读
3 回答1.1k 阅读✓ 已解决
2 回答1.1k 阅读✓ 已解决
5 回答909 阅读✓ 已解决
6 回答762 阅读✓ 已解决