javascript - 如何找到两个或多个节点的最近共同祖先?

标签 javascript jquery

用户在 HTML 页面中选择两个或多个元素。我想要完成的是找到这些元素的共同祖先(如果之前没有找到, body 节点将是共同的祖先)?

P.S:它可以用 XPath 实现,但对我来说不是一个更好的选择。也可以通过 css 选择器解析找到它,但我认为这是一个肮脏的方法 (?)

谢谢。

最佳答案

这是一个更高效的纯 JavaScript 版本。

function parents(node) {
  var nodes = [node]
  for (; node; node = node.parentNode) {
    nodes.unshift(node)
  }
  return nodes
}

function commonAncestor(node1, node2) {
  var parents1 = parents(node1)
  var parents2 = parents(node2)

  if (parents1[0] != parents2[0]) throw "No common ancestor!"

  for (var i = 0; i < parents1.length; i++) {
    if (parents1[i] != parents2[i]) return parents1[i - 1]
  }
}

关于javascript - 如何找到两个或多个节点的最近共同祖先?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3960843/

相关文章:

javascript - 适用于所有浏览器的 window.href

php - 在表单中创建黑名单过滤器以避免某些单词

jquery - Ajax 将列表作为字符串发送,而不仅仅是列表

javascript - Jquery 提交不起作用

jquery - jstree初始节点id

javascript - jQuery .ajax() 访问 javascript 循环中的 beforeSend 局部变量

javascript - 如何在不取消页面卸载的情况下发送 AJAX PUT 请求?

javascript - 每次测试后重置服务对象

javascript - 如何在触发 setinterval 函数或即将结束时找到开始和/或结束时间戳

jquery - Struts2/jQuery : resume link href redirect after e. PreventDefault();