--- title: visibility slug: Web/CSS/visibility tags: - CSS - Propriété - Reference translation_of: Web/CSS/visibility ---
La propriété visibility
peut être utilisée afin de cacher un élément tout en conservant occupé l'espace dans lequel il aurait été visible. Elle permet aussi de masquer des lignes ou des colonnes dans un tableau (cf. {{HTMLElement("table")}}).
Le code source de cet exemple interactif est disponible dans un dépôt GitHub. Si vous souhaitez contribuez à ces exemples, n'hésitez pas à cloner https://github.com/mdn/interactive-examples et à envoyer une pull request !
Note : Afin de cacher un élément et de le retirer de la disposition du document, on utilisera plutôt la propriété {{cssxref("display")}} avec la valeur none
.
/* Avec un mot-clé */ visibility: visible; visibility: hidden; visibility: collapse; /* Valeurs globales */ visibility: inherit; visibility: initial; visibility: unset;
La propriété visibility
est définie avec l'un des mots-clés suivants.
visible
hidden
visibility:visible
. L'élément ne pourra plus recevoir le focus (cf. la navigation au clavier avec les tabulations).collapse
{{cssxref("display")}}: none
aux colonnes/lignes du tableau). La taille des autres lignes et colonnes continue d'être calculée comme si les lignes et colonnes masquées étaient présentes. Cela a été conçu afin de pouvoir retirer rapidement des lignes et/ou des colonnes sans avoir à recalculer les dimensions pour l'ensemble du tableau.collapse
est traité comme hidden
.Les valeurs de visibilité peuvent être interpolées entre visible et masqué. L'une des valeurs de début ou de fin doit donc être visible
, sinon il n'y aura pas d'interpolation. L'interpolation est discrète (passage direct d'un état à l'autre), les valeurs supérieures à 0 sont considérées équivalentes à visible
. On pourra plutôt utiliser {{cssxref("opacity")}} pour créer un effet doux plutôt que de masquer/rendre visible l'élément brusquement.
<p> On peut dire tout ce qu'on veut ici, ce ne sera pas lisible de toute façon. </p> <p class="coucou"> Alors que là, on a la bonne classe. Coucou tout le monde :) </p> <p> Et on repasse en mode invisible. </p>
p { /* les paragraphes ne seront pas visibles */ visibility: hidden; } p.coucou { /* sauf ceux avec la classe coucou */ visibility: visible; }
{{EmbedLiveSample("Exemple_simple")}}
<table> <tr> <td>Jean</td> <td>Biche</td> </tr> <tr class="col"> <td>Hit</td> <td>Girl</td> </tr> <tr> <td>Super</td> <td>Cochon</td> </tr> </table>
tr.col { /* les lignes de tableau avec la classe */ /* col seront repliées */ visibility: collapse; }
{{EmbedLiveSample("Exemple_sur_un_tableau")}}
Utiliser la propriété visibility
avec la valeur hidden
retirera l'objet de l'arbre d'accessibilité. Les éléments ciblés, ainsi que leurs éléments descendants ne seront plus annoncés par les lecteurs d'écran.
visibility:collapse
est absent ou incorrect pour certains navigateurs récents. Dans de nombreux cas, il n'est pas correctement traité comme visibility:hidden
sur les éléments qui ne sont pas des lignes et/ou des colonnes de tableau.visibility:collapse
peut modifier la disposition d'un tableau si le tableau possède des tableaux imbriqués dont les cellules sont repliées, sauf si visibility:visible
est défini explicitement sur les tableaux imbriqués.Spécification | État | Commentaires |
---|---|---|
{{SpecName('CSS3 Flexbox', '#visibility-collapse', 'visibility')}} | {{Spec2('CSS3 Flexbox')}} | Définition de la valeur collapse pour les éléments flexibles. |
{{SpecName('CSS3 Box', '#visibility-prop', 'visibility')}} | {{Spec2('CSS3 Box')}} | Aucune modification. |
{{SpecName('CSS3 Transitions', '#animatable-css', 'visibility')}} | {{Spec2('CSS3 Transitions')}} | visibility peut désormais être animée. |
{{SpecName('CSS2.1', 'visufx.html#visibility', 'visibility')}} | {{Spec2('CSS2.1')}} | Définition initiale. |
{{cssinfo}}
{{Compat("css.properties.visibility")}}