657 B
657 B
title, type, tags, author, cover, dateModified
| title | type | tags | author | cover | dateModified | |
|---|---|---|---|---|---|---|
| Get element ancestors | snippet |
|
chalarangelo | interior-8 | 2021-01-05T22:45:34+02:00 |
Returns all the ancestors of an element from the document root to the given element.
- Use
Node.parentNodeand awhileloop to move up the ancestor tree of the element. - Use
Array.prototype.unshift()to add each new ancestor to the start of the array.
const getAncestors = el => {
let ancestors = [];
while (el) {
ancestors.unshift(el);
el = el.parentNode;
}
return ancestors;
};
getAncestors(document.querySelector('nav'));
// [document, html, body, header, nav]