<details> : l'élément de divulgation des détails
Baseline Widely available
This feature is well established and works across many devices and browser versions. It’s been available across browsers since January 2020.
L'élément HTML <details>
est utilisé comme un outil permettant de révéler une information. Un résumé ou un intitulé peuvent être fournis grâce à un élément <summary>
.
La plupart du temps, le contrôle utilisé pour cet élément est un triangle qui est tourné ou tordu afin d'indiquer si l'élément est révélé ou non. Si le premier élément fils de l'élément <details>
est un élément <summary>
, c'est le contenu de ce dernier qui est utilisé comme intitulé pour le contenu à révéler (l'intitulé est donc toujours visible).
Exemple interactif
Note : L'utilisation courante d'un triangle qui tourne ou s'enroule pour représenter l'ouverture ou la fermeture du widget explique pourquoi on les appelle parfois « twisties » en anglais.
Un widget <details>
peut être dans l'un des deux états suivants. L'état par défaut fermé affiche uniquement le triangle et l'étiquette à l'intérieur du <summary>
(ou une chaîne par défaut définie par l'agent utilisateur si aucun <summary>
).
Lorsque l'utilisateur clique sur le widget ou le met au point, puis appuie sur la barre d'espacement, il s'ouvre par "torsion", révélant son contenu :
À partir de là, vous pouvez utiliser les feuilles de style en cascade pour donner un style au widget de divulgation, et vous pouvez ouvrir et fermer le widget de façon programmatique en définissant ou en supprimant son attribut open
.
Par défaut, lorsqu'il est fermé, le widget est seulement assez haut pour afficher le triangle de divulgation et le résumé. Lorsqu'il est ouvert, il s'étend pour afficher les détails qu'il contient.
Note : Malheureusement, à l'heure actuelle, il n'existe aucun moyen intégré d'animer la transition entre l'ouverture et la fermeture.
Les implémentations entièrement conformes aux normes appliquent automatiquement le code CSS display: list-item
à l'élément <summary>
. Vous pouvez l'utiliser pour personnaliser davantage son apparence. Voir Personnaliser l'apparence pour plus de détails.
Catégories de contenu | Contenu de flux, racine de section, contenu interactif, contenu tangible. |
---|---|
Contenu autorisé |
Un élément
<summary>
suivi par du
contenu de flux.
|
Omission de balises | Aucune, la balise d'ouverture et la balise de fermeture sont obligatoires. |
Parents autorisés | Tout élément acceptant du contenu de flux. |
Rôle ARIA implicite | group |
Rôles ARIA autorisés | Aucun. |
Interface DOM | HTMLDetailsElement |
Attributs
Comme tous les éléments HTML, cet élément accepte les attributs universels.
open
-
Cet attribut booléen indique si les détails — c'est-à-dire le contenu de l'élément
<details>
— sont actuellement visibles ou non. Les détails sont affichés lorsque cet attribut existe, ou cachés lorsque cet attribut est absent. Par défaut, cet attribut est absent, ce qui signifie que les détails ne sont pas visibles.Note : Vous devez supprimer entièrement cet attribut pour que les détails soient cachés. Attention,
open="false"
rend les détails visibles, car cet attribut est booléen.
Évènements
En plus des évènements classiques pris en charge par les éléments HTML, l'élément <details>
prend en charge l'évènement toggle qui est envoyé sur l'élément lorsque son état change entre ouvert et fermé (que ce soit dans un sens ou dans l'autre). L'évènement est envoyé après que l'état ait été changé et si plusieurs changements d'état ont eu lieu avant que le navigateur envoie l'évènement, le navigateur fusionnera ces évènements en un seul.
On peut alors écouter cet évènement en JavaScript afin de détecter le changement d'état du contrôle :
details.addEventListener(
"toggle",
function (evt) {
if (details.open) {
/* l'état est passé en "ouvert" */
} else {
/* l'état est passé en "fermé" */
}
},
false,
);
Exemples
Un exemple simple
Dans cet exemple, on utilise un élément <details>
sans résumé/intitulé.
<details>
<p>
Il faut un ordinateur équipé d'un système d'exploitation. L'ordinateur doit
disposer d'une mémoire et, idéalement, d'une sorte de stockage à long terme.
Un dispositif d'entrée et un dispositif de sortie sont recommandés.
</p>
</details>
Ici, le navigateur utilisera alors un intitulé par défaut (généralement, ce sera "Détails").
Résultat
Créer un contrôle déjà ouvert
Pour obtenir une boîte <details>
dans un état ouvert, il suffit d'ajouter l'attribut booléen open
:
<details open>
<summary>Configuration requise</summary>
<p>
Il faut un ordinateur équipé d'un système d'exploitation. L'ordinateur doit
disposer d'une mémoire et, idéalement, d'une sorte de stockage à long terme.
Un dispositif d'entrée et un dispositif de sortie sont recommandés.
</p>
</details>
Résultat
Personnaliser l'apparence
Utilisons un peu de CSS afin de personnaliser l'apparence du contrôle fourni par <details>
.
CSS
details {
font:
16px "Open Sans",
Calibri,
sans-serif;
width: 620px;
}
details > summary {
padding: 2px 6px;
width: 15em;
background-color: #ddd;
border: none;
box-shadow: 3px 3px 4px black;
cursor: pointer;
}
details > p {
border-radius: 0 0 10px 10px;
background-color: #ddd;
padding: 2px 6px;
margin: 0;
box-shadow: 3px 3px 4px black;
}
details[open] > summary {
background-color: #ccf;
}
Ce fragment de feuille de style CSS crée une apparence similaire à un onglet où, lorsqu'on clique sur l'onglet, il s'étend et révèle le contenu.
Le sélecteur details[open]
peut être utilisé pour donner un style à l'élément qui est ouvert.
HTML
<details open>
<summary>Configuration requise</summary>
<p>
Il faut un ordinateur équipé d'un système d'exploitation. L'ordinateur doit
disposer d'une mémoire et, idéalement, d'une sorte de stockage à long terme.
Un dispositif d'entrée et un dispositif de sortie sont recommandés.
</p>
</details>
Résultat
Personnaliser le marqueur de révélation
Le triangle généralement utilisé peut également être personnalisé. Toutefois, cette fonctionnalité a été standardisée récemment et n'est pas encore largement prise en charge. De plus, la méthode de prise en charge varie encore d'un navigateur à un autre.
L'élément <summary>
prend en charge la propriété raccourcie list-style
et ses propriétés longues, comme list-style-type
, pour changer le triangle de divulgation en ce que vous choisissez (généralement avec list-style-image
). Par exemple, nous pouvons supprimer l'icône du widget de divulgation en définissant list-style : none
.
Actuellement, Chrome ne prend pas en charge cette fonctionnalité et il faut utiliser le pseudo-élément spécifique ::-webkit-details-marker
afin de personnaliser l'apparence.
CSS
details {
font:
16px "Open Sans",
"Arial",
sans-serif;
width: 620px;
}
details > summary {
padding: 2px 6px;
width: 15em;
background-color: #ddd;
border: none;
box-shadow: 3px 3px 4px black;
list-style: none;
}
details > summary::-webkit-details-marker {
display: none;
}
details > p {
border-radius: 0 0 10px 10px;
background-color: #ddd;
padding: 2px 6px;
margin: 0;
box-shadow: 3px 3px 4px black;
}
Ce CSS crée un aspect similaire à celui d'une interface à onglets, où l'activation de l'onglet le développe et l'ouvre pour révéler son contenu.
HTML
<details open>
<summary>Configuration requise</summary>
<p>
Il faut un ordinateur équipé d'un système d'exploitation. L'ordinateur doit
disposer d'une mémoire et, idéalement, d'une sorte de stockage à long terme.
Un dispositif d'entrée et un dispositif de sortie sont recommandés.
</p>
</details>
Résultat
Spécifications
Specification |
---|
HTML Standard # the-details-element |
Compatibilité des navigateurs
BCD tables only load in the browser
Voir aussi
- L'élément
<summary>