:hover peut-il modifier les classes CSS externes ?
En CSS, nous pouvons appliquer des modifications de style aux éléments en survol à l'aide du sélecteur :hover. Cependant, que se passe-t-il si l'on souhaite modifier le CSS d'un élément d'une classe différente lorsqu'un autre élément est survolé ?
Comme les sélecteurs CSS ciblent uniquement les éléments en fonction de leur hiérarchie ou de leurs relations au sein du DOM, il n'est pas possible de directement modifier le CSS d'un élément en dehors de la portée de l'élément de survol actuel.
Options de modifications indirectes
Cependant, il existe des approches indirectes pour obtenir des effets similaires :
.item:hover .wrapper { /* Styles to be applied to '.wrapper' when '.item' is hovered */ }
.item:hover ~ .wrapper { /* Styles to be applied to '.wrapper' when '.item' or any of its siblings is hovered */ }
Solution JavaScript
Si les solutions CSS ne sont pas réalisables, vous pouvez utiliser JavaScript pour manipuler les propriétés CSS de E en fonction du état de survol de F.
<code class="javascript">document.querySelector('.item').addEventListener('mouseenter', () => { document.querySelector('.wrapper').style.backgroundColor = 'red'; }); document.querySelector('.item').addEventListener('mouseleave', () => { document.querySelector('.wrapper').style.backgroundColor = ''; });</code>
Conclusion
Bien que les sélecteurs CSS à eux seuls ne puissent pas modifier directement les classes externes, la relation parent-enfant ou frère/sœur et JavaScript fournissent des solutions indirectes pour obtenir des effets similaires.
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!