The closest() method of the Element interface traverses the element and its parents (heading toward the document root) until it finds a node that matches the specified CSS selector.
On this page
Element: closest() method
Syntax
js
closest(selectors)
Parameters
-
selectors -
A string of valid CSS selector to match the
Elementand its ancestors against.
Return value
The closest ancestor Element or itself, which matches the selectors. If there are no such element, null.
Exceptions
SyntaxErrorDOMException-
Thrown if the
selectorsis not a valid CSS selector.
Examples
HTML
html
<article>
<div id="div-01">
Here is div-01
<div id="div-02">
Here is div-02
<div id="div-03">Here is div-03</div>
</div>
</div>
</article>
JavaScript
js
const el = document.getElementById("div-03");
// the closest ancestor with the id of "div-02"
console.log(el.closest("#div-02")); // <div id="div-02">
// the closest ancestor which is a div in a div
console.log(el.closest("div div")); // <div id="div-03">
// the closest ancestor which is a div and has a parent article
console.log(el.closest("article > div")); // <div id="div-01">
// the closest ancestor which is not a div
console.log(el.closest(":not(div)")); // <article>
Specifications
| Specification |
|---|
| DOM Standard # ref-for-dom-element-closest① |
Browser compatibility
| Desktop | Mobile | |||||||||||
|---|---|---|---|---|---|---|---|---|---|---|---|---|
| Chrome | Edge | Firefox | Internet Explorer | Opera | Safari | WebView Android | Chrome Android | Firefox for Android | Opera Android | Safari on IOS | Samsung Internet | |
closest |
41 | 15 | 35 | No | 28 | 6 | 41 | 41 | 35 | 28 | 9 | 4.0 |
Compatibility notes
- In Edge 15-18
document.createElement(tagName).closest(tagName)will returnnullif the element is not first connected (directly or indirectly) to the context object, for example theDocumentobject in the case of the normal DOM.
See also
- CSS selectors module
- Other
Elementmethods that take selectors:Element.querySelector(),Element.querySelectorAll(), andElement.matches().
© 2005–2023 MDN contributors.
Licensed under the Creative Commons Attribution-ShareAlike License v2.5 or later.
https://developer.mozilla.org/en-US/docs/Web/API/Element/closest