Jeśli spojrzysz na implementację WP_Nav_Menu_Widget
klasy, zobaczysz następujący kod:
function widget($args, $instance) {
// Get menu
$nav_menu = ! empty( $instance['nav_menu'] ) ? wp_get_nav_menu_object( $instance['nav_menu'] ) : false;
if ( !$nav_menu )
return;
$instance['title'] = apply_filters( 'widget_title', empty( $instance['title'] ) ? '' : $instance['title'], $instance, $this->id_base );
echo $args['before_widget'];
if ( !empty($instance['title']) )
echo $args['before_title'] . $instance['title'] . $args['after_title'];
wp_nav_menu( array( 'fallback_cb' => '', 'menu' => $nav_menu ) );
echo $args['after_widget'];
}
Oznacza to, że nie ma szans na zaczepienie menu. Musisz więc przyjrzeć się wp_nav_menu
implementacji funkcji, w której można znaleźć następujące wiersze kodu:
$defaults = array(
'menu' => '',
'container' => 'div',
'container_class' => '',
'container_id' => '',
'menu_class' => 'menu',
'menu_id' => '',
'echo' => true,
'fallback_cb' => 'wp_page_menu',
'before' => '',
'after' => '',
'link_before' => '',
'link_after' => '',
'items_wrap' => '<ul id="%1$s" class="%2$s">%3$s</ul>',
'depth' => 0,
'walker' => '',
'theme_location' => ''
);
$args = wp_parse_args( $args, $defaults );
$args = apply_filters( 'wp_nav_menu_args', $args );
$args = (object) $args;
Tutaj widać, że wszystkie argumenty przekazane do wp_nav_menu
funkcji można zastąpić. Tak więc potrzebujesz stworzyć własny uchwyt zaczepu, który doda walkera do menu nawigacji. Może to być proste:
function myplugin_custom_walker( $args ) {
return array_merge( $args, array(
'walker' => new My_Custom_Walker(),
// another setting go here ...
) );
}
add_filter( 'wp_nav_menu_args', 'myplugin_custom_walker' );
'walker' => new Walker_Nav_Menu()
w argumentach mojego konkretnego menu, aby ponownie go zastąpić, aby stać się domyślnym walkerem dla tylko jednego menu, ale niestety to nie działa.Rozwijając odpowiedź @ Eugene'a, jeśli chcesz ograniczyć to do konkretnego menu, po prostu sprawdź identyfikator menu:
źródło
Jest to alternatywa dla celowania w menu przez
term_id
i pomyślałem, że może się przydać komuś jako sposób modyfikacji kilku menu bez konieczności sprawdzania ich identyfikatorów.Dodając
print_r($args)
do filtra zauważyłem, że$args['menu']
jest to ciąg znaków dla menu w predefiniowanych lokalizacjach motywu iWP_Term_Object
niestandardowego widżetu menu na pasku bocznym.Użyłem tego do celowania w menu za pomocą ślimaka i dodawania klasy do ich kontenera. Można kierować na wiele menu, umieszczając wspólny ciąg w swoich ślimakach. Uwaga: ślimak menu pochodzi z klucza tablicy w
register_nav_menus()
.W przypadku pojedynczego menu wystarczy sprawdzić to
$args['menu']->{slug} == 'your-slug'
zamiast bitu strpos () powyżej.źródło
Możesz dodać niestandardowy walker do menu nawigacyjnego utworzonego w widżecie za pomocą
widget_nav_menu_args
filtra dodanego w wordpress4.2.0
. Akceptuje cztery argumenty (patrzwp-includes/widgets/class-wp-nav-menu-widget.php
). Ale aby dodać tylko niestandardowy walker, wystarczy użyć pierwszego argumentu, w taki sam sposób jakwp_nav_menu_args
filtr.źródło