在JavaScript / HTML中,获取指定元素的父元素

在 JavaScript 中,获取一个元素的父元素非常简单,主要通过以下属性或方法实现:

1. 使用 parentNode 属性

返回当前节点的父节点,可能是元素节点、文档节点或文档片段节点。对于元素节点,通常就是其父元素。

javascript 复制代码
let child = document.getElementById('myElement');
let parent = child.parentNode;

2. 使用 parentElement 属性

返回当前元素的父元素节点,如果父节点不是元素(例如是文本节点或文档节点),则返回 null。推荐在只想获取元素节点时使用。

javascript 复制代码
let child = document.getElementById('myElement');
let parent = child.parentElement;

示例

html 复制代码
<div id="parent">
  <p id="child">点击我</p>
</div>

<script>
  let child = document.getElementById('child');
  console.log(child.parentNode);     // <div id="parent">...</div>
  console.log(child.parentElement);   // <div id="parent">...</div>
</script>

注意事项

  • 如果当前元素已经是根节点(如 html 元素),parentNode 返回 document,而 parentElement 返回 null
  • 对于文本节点或注释节点,parentNode 可以获取其父元素,而 parentElement 始终为 null(因为它们不是元素)。

相关方法:closest()

如果你需要向上查找匹配某个 CSS 选择器的祖先元素(包括自身),可以使用 closest() 方法。

javascript 复制代码
let ancestor = element.closest('.some-class');

该方法返回最近的匹配祖先元素,如果没有找到则返回 null

相关推荐
kyriewen6 小时前
我手写了一个 EventEmitter,面试官追问了 6 个问题——第 4 个我没答上来
前端·javascript·面试
山河木马7 小时前
矩阵专题2-怎么创建视图矩阵(uViewMatrix)
javascript·webgl·计算机图形学
tangdou3690986559 小时前
AI真好玩系列-2分钟快速了解DeepAgents | Quick Guide to DeepAgents in 2 Minutes
前端·javascript·后端
张元清9 小时前
React useIntersectionObserver Hook:懒加载与可见性检测(2026)
javascript·react.js
彭于晏爱编程9 小时前
纯 JS + Node,一个下午手搓了能读懂公司代码的 AI 助手,老板以为我转行了
前端·javascript
妙码生花10 小时前
从 PHP 到 AI + Golang,程序员自救转型手记(十四):眨眼小人登录页制作
前端·javascript·ai编程
妙码生花10 小时前
从 PHP 到 AI + Golang,程序员自救转型手记(十三):前端路由初始化
前端·javascript·ai编程
PBitW10 小时前
GPT训练我的第四天,被打惨了!!!😭😭😭
前端·javascript·面试
DarkLONGLOVE10 小时前
快速上手 Pinia!Vue3 极简状态管理使用教程
javascript·vue.js
mackbob10 小时前
.eslintrc.js详细配置说明
javascript