Skip to content

Instantly share code, notes, and snippets.

@access42
Last active February 11, 2021 07:59
Show Gist options
  • Star 5 You must be signed in to star a gist
  • Fork 0 You must be signed in to fork a gist
  • Save access42/ef9b517046b985971754086c4b937ce3 to your computer and use it in GitHub Desktop.
Save access42/ef9b517046b985971754086c4b937ce3 to your computer and use it in GitHub Desktop.
WordPress : indiquer l’item actif d’un menu dans le code HTML

WordPress : indiquer l’item actif d’un menu dans le code HTML

Ajout d’une alternative HTML à l’indication visuelle qu’un item est actif dans un menu.

La fonction ci-dessous ajoute un texte masqué hors écran pour indiquer aux personnes aveugles naviguant avec un lecteur d’écran quel item de menu est actif.

Copiez le code dans le fichier functions.php de votre thème ou de votre thème enfant.

Notes :

Inconvénient de cette technique

Ce texte masqué n’est accessible qu’aux personnes utilisant un lecteur d’écran pour consulter la page. Ajouter un attribut title sur le lien actif rendrait l’information accessible que l’on utilise un lecteur d’écran ou pas.

Autres solutions possibles

D’autres solutions sont également possibles pour indiquer l’élément actif de manière accessible.

À noter : dans Twenty Nineteen 1.4, l’item actif est indiqué avec l’attribut ARIA aria-current="page", ce qui comporte le même inconvénient que la méthode du texte masqué hors écran. En outre, cet attribut pose souci avec VoiceOver et VoiceAssistant a priori.

Références

Licence

Code distribué sous la licence GPLv2 ou ultérieure. En savoir plus sur la licence de WordPress.

En savoir plus

Conférence « Comment améliorer l’accessibilité de votre thème WordPress ? » de Marie Guillaumet.

Access42

<?php
/**
* Add HTML suffix to nav active items in the main nav
*/
class a42_active_item_walker extends Walker_Nav_Menu
{
// Function responsible for the opening <li> tag and the link
function start_el( &$output, $item, $depth = 0, $args = array(), $id = 0 ) {
$is_current_item = '';
$is_current_item_class = '';
// Replace 'twentynineteen' by your own text domain
global $text_domain; if (!$text_domain && !isset($text_domain)) $text_domain = 'twentynineteen';
// Get item classes
$total = count($item->classes);
$i = 0;
// Loop through each class to display them accordingly
foreach ($item->classes as $item_class){
$is_current_item_class .= $item_class;
// Insert white spaces if needed
if ($i > 0 && $i != $total - 1) :
$is_current_item_class .= ' ';
endif;
$i++;
}
// Add HTML in the active item
if(array_search('current-menu-item', $item->classes) != 0)
{
$is_current_item = '<span class="sr-only">' . __(' – active page', $text_domain) . '</span>';
}
// Output result
$output .= '<li class="'.$is_current_item_class.'"><a href="'.$item->url.'">'.$item->title . $is_current_item;
}
// Function responsible for the closing </li> tag is end_el
function end_el( &$output, $item, $depth = 0, $args = array() ) {
$output .= '</a></li>';
}
}
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment