Climbing up the DOM tree with vanilla JavaScript

Today, I wanted to look at two ways to climb up the DOM tree with vanilla JavaScript. Let’s dig in!
The Element.parentNode property You can use the Element.parentNode property to get the parent of an element.
<div id=”app”> <h1>Hello, world!</h1> </div>let h1 = document.querySelector(‘h1’); // returns the #app element let parent = h1.parentNode; You can also string them together to go several levels up.
let levelUpParent = h1.parentNode.parentNode; The Element.


This content originally appeared on Go Make Things and was authored by Go Make Things

Today, I wanted to look at two ways to climb up the DOM tree with vanilla JavaScript. Let’s dig in!

The Element.parentNode property

You can use the Element.parentNode property to get the parent of an element.

<div id="app">
	<h1>Hello, world!</h1>
</div>
let h1 = document.querySelector('h1');

// returns the #app element
let parent = h1.parentNode;

You can also string them together to go several levels up.

let levelUpParent = h1.parentNode.parentNode;

The Element.closest() method

You can use the Element.closest() method to get the closest parent up the DOM tree that matches against a selector.

The Element.closest() method starts with the element itself. You can start with the first parent element by pairing it with the Node.parentNode property.

<main>
	<div class="hero">
		<div id="app">
			<h1 data-sandwich>Hello, world!</h1>
		</div>
	</div>
</main>
let h1 = document.querySelector('h1');

// returns the .hero element
let hero = h1.closest('.hero');

// returns the h1 element itself
let sandwich = h1.closest('[data-sandwich]');

// Start with the element's parent
// returns null
let sandwich2 = h1.parentNode.closest('[data-sandwich]');

Creative uses for the Element.closest() method

I like to use the Element.closest() method to check if an element is or is inside of some parent element.

This is particularly useful when paired with event delegation for my event listeners.

For example, let’s say you have some buttons with some nested HTML in them, like this.

<button class="click-me">
	<span class="text-large">Click Me!</span>
	<br>
	<span class="text-small">(limited time offer)</span>
</button>

And your JavaScript to listen for clicks on those buttons looks like this.

document.addEventListener('click', function (event) {

	// Only run on .click-me buttons
	if (!event.target.matches('.click-me')) return;

	// Do stuff...

});

This will never run, because the target of the click event will almost always be the .text-large or .text-small elements. It only works if you click outside of the text in the button.

Here’s a demo.

To get around this, we can use the Element.closest() method instead.

document.addEventListener('click', function (event) {

	// Only run on .click-me buttons
	if (!event.target.closest('.click-me')) return;

	// Do stuff...

});

Here’s another demo.

There are a lot of uses for the Element.closest() method, but this is one of my favorites.

⏰🦉 Early Bird Sale! Today through Monday, get 40% off registration in the next session of the Vanilla JS Academy.


This content originally appeared on Go Make Things and was authored by Go Make Things


Print Share Comment Cite Upload Translate Updates
APA

Go Make Things | Sciencx (2022-03-17T14:30:00+00:00) Climbing up the DOM tree with vanilla JavaScript. Retrieved from https://www.scien.cx/2022/03/17/climbing-up-the-dom-tree-with-vanilla-javascript/

MLA
" » Climbing up the DOM tree with vanilla JavaScript." Go Make Things | Sciencx - Thursday March 17, 2022, https://www.scien.cx/2022/03/17/climbing-up-the-dom-tree-with-vanilla-javascript/
HARVARD
Go Make Things | Sciencx Thursday March 17, 2022 » Climbing up the DOM tree with vanilla JavaScript., viewed ,<https://www.scien.cx/2022/03/17/climbing-up-the-dom-tree-with-vanilla-javascript/>
VANCOUVER
Go Make Things | Sciencx - » Climbing up the DOM tree with vanilla JavaScript. [Internet]. [Accessed ]. Available from: https://www.scien.cx/2022/03/17/climbing-up-the-dom-tree-with-vanilla-javascript/
CHICAGO
" » Climbing up the DOM tree with vanilla JavaScript." Go Make Things | Sciencx - Accessed . https://www.scien.cx/2022/03/17/climbing-up-the-dom-tree-with-vanilla-javascript/
IEEE
" » Climbing up the DOM tree with vanilla JavaScript." Go Make Things | Sciencx [Online]. Available: https://www.scien.cx/2022/03/17/climbing-up-the-dom-tree-with-vanilla-javascript/. [Accessed: ]
rf:citation
» Climbing up the DOM tree with vanilla JavaScript | Go Make Things | Sciencx | https://www.scien.cx/2022/03/17/climbing-up-the-dom-tree-with-vanilla-javascript/ |

Please log in to upload a file.




There are no updates yet.
Click the Upload button above to add an update.

You must be logged in to translate posts. Please log in or register.