28 lines
639 B
Markdown
28 lines
639 B
Markdown
---
|
|
title: getAncestors
|
|
tags: browser,beginner
|
|
firstSeen: 2020-10-15T09:28:34+03:00
|
|
lastUpdated: 2021-01-05T22:45:34+02:00
|
|
---
|
|
|
|
Returns all the ancestors of an element from the document root to the given element.
|
|
|
|
- Use `Node.parentNode` and a `while` loop to move up the ancestor tree of the element.
|
|
- Use `Array.prototype.unshift()` to add each new ancestor to the start of the array.
|
|
|
|
```js
|
|
const getAncestors = el => {
|
|
let ancestors = [];
|
|
while (el) {
|
|
ancestors.unshift(el);
|
|
el = el.parentNode;
|
|
}
|
|
return ancestors;
|
|
};
|
|
```
|
|
|
|
```js
|
|
getAncestors(document.querySelector('nav'));
|
|
// [document, html, body, header, nav]
|
|
```
|