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
DDDOriginal
2024-12-06 07:39:11880browse

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);
});

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

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

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

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

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!

Statement:
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