您好,匿名用户

指定body节点下的任意元素节点,如何快速算出它是body的第几代,第几个子孙元素?

0 投票

我们开发时有一个需求,让我几乎崩溃。
需求总结后就是:
指定body节点下的任意元素节点,算出它是body节点的第几个儿子的,第几个孙子。这个关系可以很长。比如某些很深的元素节点,可能结论是:某元素节点是body节点的第2个儿子的第3个儿子的第1个儿子的第9个儿子。

(PS:textNode要跳过,只计算elementNode)

我实在搞不定了,搜资料也没找到对口的,求大神帮忙,分享一些资料也好啊。

用户头像 提问 2017年 3月18日 @ Corki 中士 (1,208 威望)
分享到:

1个回答

0 投票
  1. 这个需求我觉得从安置dom节点的时候就应该考虑到,比如说dom节点与一个数据结构相对应,或者对dom节点做hash(没错就是Vitrual DOM的思路)

  2. 不然最优的方案只能是逆向宽搜(通过父节点遍历到目前是第几个,如果父节点不是body就继续这步骤),不过,读取DOM节点的代价也是高昂的不亚于操作DOM节点,适用于DOM数量级较小的页面

  3. 如果上了React等,那可以简化一点,其实和第一个数据相同

用户头像 回复 2017年 3月18日 @ Kayle 中士 (1,022 威望)
提一个问题:

相关问题

0 投票
1 回复 40 阅读
用户头像 提问 5月15日 @ Sion 中士 (1,454 威望)
0 投票
1 回复 182 阅读
0 投票
1 回复 14 阅读
0 投票
1 回复 12 阅读

欢迎来到随意问技术百科, 这是一个面向专业开发者的IT问答网站,提供途径助开发者查找IT技术方案,解决程序bug和网站运维难题等。
温馨提示:本网站禁止用户发布与IT技术无关的、粗浅的、毫无意义的或者违法国家法规的等不合理内容,谢谢支持。

IT技术交流群 - 随意问
欢迎访问随意问技术百科,为了给您提供更好的服务,请及时反馈您的意见。
...