Maison >interface Web >js tutoriel >Comment itérer correctement sur les résultats `getElementsByClassName()` en JavaScript ?

Comment itérer correctement sur les résultats `getElementsByClassName()` en JavaScript ?

Susan Sarandon
Susan Sarandonoriginal
2024-12-01 06:07:13442parcourir

How to Correctly Iterate Over `getElementsByClassName()` Results in JavaScript?

Erreur : itération du résultat getElementsByClassName() avec Array.forEach

Lors de la tentative d'itération sur les éléments DOM à l'aide de getElementsByClassName() et du tableau. forEach, les utilisateurs peuvent rencontrer une erreur due au fait que getElementsByClassName() le fait ne renvoie pas de tableau.

Le résultat de getElementsByClassName() est une HTMLCollection, qui, dans les navigateurs modernes, diffère d'un tableau. Pour résoudre ce problème, convertissez HTMLCollection en tableau avant d'utiliser forEach. Ceci peut être réalisé grâce aux méthodes suivantes :

  • Utilisation de call() avec Array.prototype.forEach :
var els = document.getElementsByClassName("myclass");
Array.prototype.forEach.call(els, function(el) {
  // Do stuff here
  console.log(el.tagName);
});
  • Utilisation `[].forEach.call() :
[].forEach.call(els, function (el) {
  // Do stuff here
  console.log(el.tagName);
});
  • Utilisation de `Array.from() (ES6)** :
Array.from(els).forEach((el) => {
  // Do stuff here
  console.log(el.tagName);
});

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn