1. Go to this page and download the library: Download ucomm/a11y-menu library. Choose the download type require.
2. Extract the ZIP file and open the index.php.
3. Add this code to the index.php.
<?php
require_once('vendor/autoload.php');
/* Start to develop here. Best regards https://php-download.com/ */
// functions.php
enu location.
// this is optional if you're using a child theme with pre-registered locations
function register_nav() {
register_nav_menu('menu-name', __('Menu Name', 'text-domain'));
}
add_action('after_setup_theme', 'register_nav');
function load_scripts() {
// enqueue the base nav styles
wp_enqueue_style('a11y-menu', get_stylesheet_directory_uri() . '/vendor/ucomm/a11y-menu/dist/main.css');
// register/enqueue the JS Navigation script
wp_register_script('a11y-menu', get_stylesheet_directory_uri() . '/vendor/ucomm/a11y-menu/dist/Navigation.js', array(), false, true);
wp_enqueue_script('a11y-menu');
// the Navigation script is a dependency of the script where you wish to instantiate the class.
wp_enqueue_script('theme-script', get_stylesheet_directory_uri() . '/index.js', array('a11y-menu', false, true));
}
add_action('wp_enqueue_scripts', 'load_scripts');
/**
* header.php (or whichever file you want to use for displaying the menu)
*
* container -> this should be set to 'nav' for better accessibility and to make sure the CSS works.
* items_wrap -> ensures that you can use a custom ID for the <ul> element.
* menu_id -> The ID should be prefixed with 'am-' to act as a namespace.
* For instance, 'am-main-menu' is the default ID used by the Navigation JS class.
* However this can be overridden if you like
* walker -> the instance of the walker class
*/
$args = array(
'container' => 'nav',
'items_wrap' => '<ul id="%1$s" class="nav navbar-nav %2$s">%3$s</ul>',
'menu_id' => 'am-main-menu',
'theme_location' => 'menu-name',
'walker' => new A11y\Menu_Walker()
);
wp_nav_menu($args);
Loading please wait ...
Before you can download the PHP files, the dependencies should be resolved. This can take some minutes. Please be patient.