Maison >interface Web >tutoriel CSS >Pourquoi la décoration de texte n'hérite-t-elle pas correctement en CSS ?

Pourquoi la décoration de texte n'hérite-t-elle pas correctement en CSS ?

Barbara Streisand
Barbara Streisandoriginal
2024-12-07 07:21:19801parcourir

Why Doesn't Text Decoration Inherit Correctly in CSS?

Problème de remplacement de la décoration de texte CSS

Dans la hiérarchie des propriétés CSS, les propriétés spécifiques ont priorité sur les propriétés héritées des éléments parents. Cependant, la propriété text-decoration présente une exception à cette règle.

Problème :

Considérez le code suivant :

<a href="#">
  A <span>red</span> anchor
</a>
a {
  color: blue;
  font-family: Times New Roman;
  text-decoration: underline;
}

span {
  color: red;
  font-family: Arial;
  text-decoration: none;
}

Comme démontré dans ce [démo](http://jsfiddle.net/5t9sV/), la propriété text-decoration de l'élément enfant span ne remplace pas la décoration soulignée du parent a element.

Raison :

Selon la spécification CSS, la propriété text-decoration des éléments descendants "ne peut avoir aucun effet sur la décoration de l'ancêtre." Cela signifie essentiellement que les décorations de texte sont appliquées sur l'ensemble de l'élément, quels que soient les éléments enfants présents.

Solution :

En CSS3, il existe une propriété appelée text-decoration-skip qui peut être appliqué à l'élément enfant pour ignorer la décoration de texte héritée. Cependant, cela ne fonctionne que pour les éléments en ligne (par exemple, span) et les navigateurs pris en charge peuvent varier.

Par exemple, pour faire apparaître le texte à l'intérieur de l'élément span sans souligner, vous pouvez ajouter :

span {
  text-decoration-skip: ink;
}

Notez que ink est l'un des les valeurs possibles pour text-decoration-skip, qui inclut les caractères, les espaces et les objets incorporés.

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