Maison > interface Web > tutoriel CSS > Comment styliser dynamiquement plusieurs éléments avec la même classe par survol d'événements en JavaScript ?

Comment styliser dynamiquement plusieurs éléments avec la même classe par survol d'événements en JavaScript ?

Susan Sarandon
Libérer: 2024-10-24 07:48:02
original
243 Les gens l'ont consulté

How to Dynamically Style Multiple Elements with the Same Class by Event Hovering in JavaScript?

Comment styliser plusieurs éléments avec la même classe à l'aide de JavaScript

Lorsque vous travaillez avec HTML et CSS, vous devez parfois modifier dynamiquement le style de plusieurs éléments avec la même classe. Dans ce cas, la question concerne l'utilisation de getElementsByClassName pour changer la couleur d'arrière-plan de tous les éléments d'une classe donnée lorsque vous survolez un autre élément de page.

Le problème se pose car getElementsByClassName renvoie une collection d'éléments, pas un seul élément. . Pour styliser plusieurs éléments, vous devez parcourir la collection et appliquer les modifications de style à chaque élément.

<code class="js">var elements = document.getElementsByClassName('classname');
for (var i = 0; i < elements.length; i++) {
  elements[i].style.backgroundColor = 'red';
}
Copier après la connexion

Un autre problème est que l'événement de survol n'est pas correctement attaché à l'élément cible. Dans le code d'origine, l'événement onmouseover est attaché à l'élément déclencheur (celui survolé). Pour modifier le style des éléments cibles, l'événement doit être attaché aux éléments cibles eux-mêmes.

<code class="html"><th class="classname" onmouseover="changeColor(this)">Hover Here</th></code>
Copier après la connexion

Enfin, il est important de noter que les gestionnaires d'événements en ligne comme onmouseover ne sont pas recommandés. Au lieu de cela, vous devez utiliser des écouteurs d'événements pour attacher des gestionnaires d'événements aux éléments.

<code class="js">function changeColor(element) {
  element.style.backgroundColor = 'red';
}

document.querySelectorAll('.classname').forEach((element) => {
  element.addEventListener('mouseover', () => {
    changeColor(element);
  });
});</code>
Copier après la connexion

En utilisant ces techniques, vous pouvez modifier dynamiquement le style de plusieurs éléments avec la même classe lorsque vous survolez un autre élément de page.

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!

source:php
Déclaration de ce site Web
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
Derniers articles par auteur
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal