Maison >interface Web >tutoriel CSS >Pourquoi ne ::après l'affichage du contenu pour les éléments d'entrée en HTML5 ?

Pourquoi ne ::après l'affichage du contenu pour les éléments d'entrée en HTML5 ?

Susan Sarandon
Susan Sarandonoriginal
2024-10-24 17:45:021057parcourir

Why Won't ::after Content Display for Input Elements in HTML5?

Pseudo-éléments CSS pour les champs de saisie

En HTML5, l'ajout d'indices visuels aux entrées de formulaire à l'aide de pseudo-éléments CSS peut améliorer l'expérience utilisateur. On peut tenter d'utiliser les pseudo-éléments ::before et ::after pour le style, comme le montre l'exemple suivant :

<code class="css">input::after         { display: inline; }
input:valid::after   { content: ' ✓ '; color: #ddf0dd; }
input:invalid::after { content: ' ✗ '; color: #f0dddd; }</code>

Cependant, on peut rencontrer des difficultés pour afficher le contenu ::after pour les éléments d'entrée. . Malgré l'utilisation de deux-points simples et doubles, la suppression des pseudo-classes et l'expérimentation avec différents navigateurs, le contenu reste invisible.

Alors que les pseudo-éléments ::after fonctionnent de manière transparente sur des éléments tels que div, span, p et q, ce n'est pas le cas pour les éléments d'entrée. Ce comportement découle d'un attribut fondamental de ces éléments : ils manquent de contenu dans l'arborescence des documents.

Le rôle du contenu des éléments

Selon la spécification CSS (http:// www.w3.org/TR/CSS21/generate.html), ::after les pseudo-éléments nécessitent explicitement des éléments avec un contenu d'arborescence de documents afin de restituer leur contenu. Les éléments d'entrée, similaires à img et br, ne contiennent pas un tel contenu. Par conséquent, de par leur conception, les navigateurs n'afficheront pas le contenu ::after pour les champs de saisie.

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