Maison > interface Web > tutoriel CSS > Pourquoi WebKit ne parvient-il pas à appliquer les styles :hover sur plusieurs éléments frères et sœurs adjacents ?

Pourquoi WebKit ne parvient-il pas à appliquer les styles :hover sur plusieurs éléments frères et sœurs adjacents ?

Linda Hamilton
Libérer: 2024-10-24 04:25:31
original
291 Les gens l'ont consulté

Why Does WebKit Fail to Apply :hover Styles on Multiple Adjacent-Sibling Elements?

Problème WebKit : survolez une pseudo-classe avec plusieurs sélecteurs de frères et sœurs adjacents

Les navigateurs Web rencontrent généralement des difficultés pour gérer la pseudo-classe :hover dans en conjonction avec des sélecteurs de frères et sœurs adjacents. En particulier, WebKit (Safari et Chrome) rencontre des difficultés lors de l'application des styles :hover à une série d'éléments frères adjacents.

Défi :

L'exemple suivant illustre le problème :

div:hover + a + div { /* styles here */ }
Copier après la connexion

Dans ce cas, WebKit ne parvient pas à appliquer les styles au deuxième div lorsque la souris le survole directement. Cependant, si la souris survole d'abord l'élément d'ancrage précédent, puis survole le deuxième div, les styles sont appliqués comme prévu.

Solution :

Une solution de contournement pour ce bug implique une fausse animation sur l'élément body :

body { -webkit-animation: bugfix infinite 1s; }

@-webkit-keyframes bugfix {
  from { padding: 0; }
  to { padding: 0; }
}
Copier après la connexion

Cette solution introduit une animation triviale qui oblige WebKit à restituer l'élément body, résolvant ainsi le problème des pseudo-classes de survol et de plusieurs frères et sœurs adjacents sélecteurs.

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