Home > Web Front-end > JS Tutorial > Why Doesn't `document.getElementsByClassName().forEach` Work, and How Can I Fix It?

Why Doesn't `document.getElementsByClassName().forEach` Work, and How Can I Fix It?

DDD
Release: 2024-12-06 07:39:11
Original
935 people have browsed it

Why Doesn't `document.getElementsByClassName().forEach` Work, and How Can I Fix It?

Using Array.forEach with getElementsByClassName

When attempting to iterate over DOM elements using document.getElementsByClassName( "myclass" ).forEach, one may encounter the error "document.getElementsByClassName("myclass").forEach is not a function." This occurs because the result of getElementsByClassName is not an array but an HTMLCollection.

To resolve this issue, one must convert the HTMLCollection into an array before using forEach. This can be done using the Array.prototype.forEach.call method with the HTMLCollection as the this value:

var els = document.getElementsByClassName("myclass");
Array.prototype.forEach.call(els, function(el) {
    // Do stuff here
    console.log(el.tagName);
});
Copy after login

Alternatively, one can use [].forEach.call:

[].forEach.call(els, function (el) {...});
Copy after login

In ES6, the Array.from function can be used:

Array.from(els).forEach((el) => {
    // Do stuff here
    console.log(el.tagName);
});
Copy after login

The above is the detailed content of Why Doesn't `document.getElementsByClassName().forEach` Work, and How Can I Fix It?. For more information, please follow other related articles on the PHP Chinese website!

source:php.cn
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template