Files
30-seconds-of-code/snippets/getAncestors.md
Isabelle Viktoria Maciohsek 920a0c390b Update snippet descriptions
2020-10-19 22:49:51 +03:00

26 lines
565 B
Markdown

---
title: getAncestors
tags: browser,beginner
---
Returns all the ancestors of an element from the document root to the given element.
- Use a `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]
```