ARIA : rôle treeitem
Le rôle treeitem
est un élément dans une arborescence (tree
).
Description
Une arborescence (tree
en anglais) est une liste hiérarchique avec des nœuds parents et enfants pouvant être développés ou réduits. Un treeitem
est un nœud de cette arborescence. La racine de l'arborescence possède le rôle tree
, mais tous les nœuds sont des éléments treeitem
, même s'ils contiennent eux-mêmes des nœuds enfants treeitem
.
Un exemple d'« arborescence » est une interface de sélection de fichiers : une vue arborescente affichant des dossiers et des fichiers. Chaque dossier et fichier est un treeitem
. Les dossiers, qui sont des éléments treeitem
, peuvent être développés pour révéler leur contenu (fichiers, dossiers ou les deux, tous étant des treeitem
) ou réduits pour masquer leur contenu.
Dans une hiérarchie d'arborescence, le nœud racine possède le rôle tree
. Tous les autres nœuds, sauf la racine, ont le rôle treeitem
, qu'ils aient ou non des enfants. Un treeitem
qui est parent est un nœud parent. Un treeitem
qui n'est pas parent est un nœud final.
Les éléments de l'arborescence ayant des enfants peuvent être développés ou réduits, affichant ou masquant leurs enfants. Un nœud parent développé, dont les enfants sont visibles, est un nœud ouvert. Un nœud parent réduit, dont les enfants sont masqués, est un nœud fermé.
Chaque nœud parent contient ou possède un élément avec le rôle group
. Un nœud parent est une collection extensible d'éléments treeitem
. Ces nœuds enfants ne sont pas des descendants directs du parent : ils doivent être inclus dans un élément ayant le rôle group
.
Chaque nœud parent doit inclure l'attribut aria-expanded
. Il est défini à false
lorsque le nœud est réduit, et à true
lorsqu'il est ouvert. Les nœuds finaux ne doivent pas avoir l'attribut aria-expanded
, car sa présence indique aux technologies d'assistance que le nœud est parent.
Note : Les vues arborescentes ARIA utilisent une navigation plus proche des applications natives que des applications web, et sont principalement naviguées avec les flèches du clavier plutôt qu'avec Tab. Ce type de navigation est inhabituel pour la plupart des contenus web, mais normal et attendu pour les applications natives. Pour cette raison, envisagez d'autres solutions pour répondre à votre besoin avant de créer une vue arborescente.
Tout élément ayant le rôle treeitem
doit être imbriqué dans, ou possédé par, un élément ayant le rôle tree
. Les éléments de l'arborescence peuvent être enfants de tree
, de treeitem
, ou d'un élément ayant le rôle group
contenu ou possédé par un élément ayant le rôle tree
ou treeitem
. Si un treeitem
n'est pas imbriqué dans une arborescence, ou dans un group
possédé par une arborescence, incluez l'identifiant id
du treeitem
dans la valeur de l'attribut aria-owns
de l'élément possédant (tree
, treeitem
ou group
).
Les arborescences peuvent être à « sélection unique », permettant à l'utilisateur·ice de choisir un seul treeitem
pour une action, ou à « sélection multiple », où il·elle peut sélectionner plusieurs nœuds treeitem
pour une action. Dans les deux cas, pour être accessibles au clavier, la gestion de la sélection doit être assurée pour tous les descendants de l'arborescence.
Dans les arborescences à sélection unique, un seul treeitem
peut avoir aria-selected
(ou aria-checked
) défini à true
. Lorsqu'une arborescence à sélection unique reçoit la sélection, si aucun treeitem
n'est sélectionné avant, la sélection est placée sur le premier treeitem
. Si un treeitem
est déjà sélectionné, la sélection est placée sur ce treeitem
ayant aria-selected="true"
.
Tous les nœuds sélectionnables mais non sélectionnés ont soit aria-selected
, soit aria-checked
défini à false
. Si l'arborescence contient des nœuds non sélectionnables, n'ajoutez pas ces attributs, car leur présence indique aux technologies d'assistance que le nœud est sélectionnable.
Un seul nœud peut être sélectionné à la fois, sauf si le nœud racine possède aria-multiselectable="true"
.
Dans une arborescence à sélection multiple, si aucun élément n'est sélectionné avant la sélection, la sélection est placée sur le premier treeitem
. Si un ou plusieurs éléments sont déjà sélectionnés, la sélection est placée sur le premier élément sélectionné.
Dans les arborescences à sélection multiple, tous les éléments sélectionnés ont soit aria-selected="true"
, soit aria-checked="true"
. Tous les nœuds sélectionnables mais non sélectionnés doivent avoir aria-selected="false"
ou aria-checked="false"
.
On peut utiliser soit aria-selected
, soit aria-checked
pour indiquer la sélection des éléments treeitem
. Certaines interfaces utilisent aria-selected
pour la sélection unique et aria-checked
pour la sélection multiple.
L'utilisation simultanée de aria-selected
et aria-checked
dans une même arborescence est fortement déconseillée. Ne les utilisez ensemble que si leur signification et leur usage sont différents, que cela est clair pour l'utilisateur·ice, et que l'interface propose un contrôle distinct pour chaque état.
Dans les arborescences à sélection multiple, l'état sélectionné doit être indépendant de la sélection clavier. Par exemple, dans un explorateur de fichiers, l'utilisateur·ice peut déplacer la sélection pour choisir plusieurs fichiers à copier ou déplacer. La conception visuelle doit clairement distinguer les éléments sélectionnés de l'élément ayant la sélection.
Si l'ensemble des éléments treeitem
disponibles n'est pas présent dans le DOM (chargement dynamique lors du déplacement ou du défilement), chaque treeitem
doit avoir aria-level
, aria-setsize
et aria-posinset
renseignés.
Un treeitem
doit obligatoirement avoir un nom accessible. En général, ce nom provient du contenu du treeitem
. Il peut aussi être défini via aria-label
ou aria-labelledby
.
Propriétés, états et rôles WAI-ARIA associés
tree
-
Nœud racine d'une liste hiérarchique de nœuds parents et enfants
treeitem
pouvant être développés ou réduits. group
-
Identifie un ensemble d'enfants
treeitem
. aria-expanded
-
Défini sur le nœud racine
tree
et sur les nœudsgroup
parents detreeitem
, pour indiquer si la vue arborescente est développée (true
) ou réduite (false
). aria-selected
-
Défini à
true
oufalse
, indique qu'untreeitem
est sélectionnable et s'il est actuellement sélectionné. aria-checked
-
Défini à
true
oufalse
, indique que letreeitem
peut être coché et s'il l'est actuellement.
Interactions au clavier
Pour une arborescence verticale (orientation par défaut) :
Flèche vers la droite |
|
Flèche vers la gauche |
|
Flèche vers le bas | Déplace la sélection sur le nœud suivant sélectionnable, sans ouvrir ni fermer de nœud. |
Flèche vers le haut | Déplace la sélection sur le nœud précédent sélectionnable, sans ouvrir ni fermer de nœud. |
Début | Déplace la sélection sur le premier nœud de l'arborescence, sans ouvrir ni fermer de nœud. |
Fin | Déplace la sélection sur le dernier nœud sélectionnable, sans ouvrir le nœud. |
Entrée | Effectue l'action par défaut sur le nœud sélectionné. Pour les nœuds parents, ouvre ou ferme le nœud. Dans les arborescences à sélection unique, si le nœud n'a pas d'enfant, sélectionne le nœud si ce n'est pas déjà le cas (action par défaut). |
Taper un caractère* |
|
* (optionnel) | Développe tous les nœuds frères au même niveau que le nœud courant. |
* La recherche rapide (saisie semi-automatique) est recommandée pour toutes les arborescences, surtout si elles comportent plus de 7 nœuds racines.
Interactions clavier pour la sélection multiple
Il existe deux modèles d'interaction pour les arborescences à sélection multiple : vous pouvez exiger que l'utilisateur·ice maintienne une touche de modification (Maj ou Ctrl) lors de la navigation pour ne pas perdre l'état de sélection, mais le modèle qui ne nécessite pas de maintenir une touche est recommandé.
Modèle recommandé pour la sélection multiple
Espace | Active ou désactive l'état sélectionné du nœud ayant la sélection. |
Maj + Flèche vers le bas (optionnel) | Déplace la sélection sur le nœud suivant et active/désactive son état sélectionné. |
Maj + Flèche vers le haut (optionnel) | Déplace la sélection sur le nœud précédent et active/désactive son état sélectionné. |
Maj + Espace (optionnel) | Sélectionne les nœuds contigus du dernier nœud sélectionné jusqu'au nœud courant. |
Ctrl + Maj + Début (optionnel) | Sélectionne le nœud ayant la sélection et tous les nœuds jusqu'au premier. Optionnellement, déplace la sélection sur le premier nœud. |
Ctrl + Maj + Fin (optionnel) | Sélectionne le nœud ayant la sélection et tous les nœuds jusqu'au dernier. Optionnellement, déplace la sélection sur le dernier nœud. |
Ctrl + A (optionnel) | Sélectionne tous les nœuds de l'arborescence. Optionnellement, si tous les nœuds sont sélectionnés, cette touche peut aussi tout désélectionner. |
Exemples
Voici comment baliser une liste de répertoires de cours de développement web sous forme de vue arborescente :
<div>
<h3 id="treeLabel">Parcours d'apprentissage développeur·euse</h3>
<ul role="tree" aria-labelledby="treeLabel">
<li role="treeitem" aria-expanded="true">
<span>Web</span>
<ul role="group">
<li role="treeitem" aria-expanded="false">
<span>Langages</span>
<ul role="group">
<li role="treeitem" aria-expanded="false">
<span>HTML</span>
<ul role="group">
<li role="treeitem">Structure du document</li>
<li role="treeitem">Éléments d'en-tête</li>
<li role="treeitem">Éléments sémantiques</li>
<li role="treeitem">Attributs</li>
<li role="treeitem">Formulaires web</li>
</ul>
</li>
<li role="treeitem">CSS</li>
<li role="treeitem">JavaScript</li>
</ul>
</li>
<li role="treeitem" aria-expanded="false">
<span>Accessibilité</span>
<ul role="group">
<li role="treeitem" aria-label="accessibility object model">AOM</li>
<li role="treeitem">WCAG</li>
<li role="treeitem">ARIA</li>
</ul>
</li>
<li role="treeitem" aria-expanded="false">
<span>Performance web</span>
<ul role="group">
<li role="treeitem">Temps de chargement</li>
</ul>
</li>
<li role="treeitem">API</li>
</ul>
</li>
</ul>
</div>
Ce balisage fournit la sémantique d'une vue arborescente, mais pas l'interactivité. Celle-ci doit être ajoutée en JavaScript.
Si les éléments de l'arborescence ne sont pas sélectionnables par défaut, JavaScript peut être utilisé pour ajouter tabIndex="-1"
à tous les treeitem
sauf celui qui doit recevoir la sélection lors de l'entrée dans l'arborescence, qui doit avoir tabIndex="0"
.
Toutes les fonctionnalités clavier décrites dans la section « Interactions au clavier » ainsi que les événements de pointeur doivent être programmés, y compris la gestion de la sélection, la navigation dans l'arborescence, le développement/réduction des nœuds parents et la gestion de la sélection.
Si l'arborescence comporte plus de 7 éléments, il est recommandé d'inclure la recherche rapide (saisie semi-automatique).
Spécifications
Specification |
---|
Accessible Rich Internet Applications (WAI-ARIA)> # treeitem> |
Unknown specification> |