Prepare repository for merge

This commit is contained in:
Angelos Chalaris
2023-05-01 22:35:56 +03:00
parent fc4e61e6fa
commit b3ad01863a
578 changed files with 0 additions and 0 deletions

View File

@ -0,0 +1,29 @@
---
title: Get element ancestors
type: snippet
tags: [browser]
author: chalarangelo
cover: interior-8
dateModified: 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]
```