Explain Codes LogoExplain Codes Logo

Iterating over result of getElementsByClassName using Array.forEach

javascript
prompt-engineering
functions
callbacks
Alex KataevbyAlex Kataev·Nov 20, 2024
TLDR
// Use Array.from to iterate over elements with forEach Array.from(document.getElementsByClassName('your-class')).forEach(el => { // Work with element el here, it is lonely and it craves your functionality });

Leverage Array.from() to transform the HTMLCollection into an iterable array. This allows you to use the forEach for direct element iteration because elements are shy and won't iterate themselves 🙃.

Step-by-step guide to using Array.forEach with getElementsByClassName

Solution 1: Directly applying Array.prototype.forEach.call

Array.prototype.forEach.call(document.getElementsByClassName('your-class'), el => { // this barrel roll over HTML elements won't throw a JS tantrum });

As a JavaScript ninja, use Array.prototype.forEach.call() to apply forEach directly on the HTMLCollection.

Solution 2: Using spread syntax for ES6 fancy pants

[...document.getElementsByClassName('your-class')].forEach(el => { // let's sprinkle some forEach magic on each element });

In the land of ES6, you can use the spread syntax to convert your chained container HTMLCollection into a butterfly array and it will happily obey forEach.

Solution 3: Stumbling over older browser's stone path

// Transpile this ES6 code for compatibility with older browsers [...document.getElementsByClassName('your-class')].forEach(el => { // this will even work in the forgotten realms of Internet Explorer });

For those brave souls who still venture in the realms of Internet Explorer and older browsers, beware! Gatekeepers called ES6 features might block your path. Fear not, the Babel tool will transform them into harmless ES5, so your journey can continue.

Solution 4: Unleash the power of querySelectorAll

document.querySelectorAll('.your-class').forEach(el => { // pretty and performant, the full package! });

Switch getElementsByClassName with querySelectorAll if you want your code to not only work but also have a model-like performance.

Digging deeper : Exploring alternative ways and gotchas

Avoiding the tricks of sneaky not-so HTMLElements

Array.from(document.getElementsByClassName('your-class')).forEach(el => { if(el instanceof HTMLElement){ // Safe to proceed. The element has been confirmed not an alien spy } });

Applying functions on DOM elements is fun, but watch out! Some elements might be impostor aliens, they're not HTMLElements. Use instanceof to detect and avoid them.

For the traditionalists: Using for...of loop

for (let el of document.getElementsByClassName('your-class')) { // Old but gold, kind of like that ring in Lord of the Rings }

If you stick to old school ways, the for...of loop will hold your hand. It'll faithfully traipse through each HTMLCollection, no sweat.

What's the deal with NodeList and HTMLCollection

NodeLists and HTMLCollections are not just species from the DOM Zoo, they have different wand capabilities. NodeList from querySelectorAll has its own built-in forEach magic spell:

document.querySelectorAll('.your-class').forEach(el => { // Abracadabra! forEach straight out of the box });