Отображение названия меню с помощью wp_nav_menu


17

У меня есть пользовательское меню, которое я могу нормально вызвать с помощью wp_nav_menu. Есть ли способ отобразить имя меню внутри тега h3 перед меню?

Ex.

<h3>My Menu Name</h3>
<nav>
<ul>
<li>Menu Item 1</li>
<li>Menu Item 2</li>
</ul>
</nav>

Ответы:


15

Если вы знаете, что такое меню, то все будет проще, в противном случае вы можете использовать эту функцию, чтобы получить меню в указанном месте.

<?php
function wpse45700_get_menu_by_location( $location ) {
    if( empty($location) ) return false;

    $locations = get_nav_menu_locations();
    if( ! isset( $locations[$location] ) ) return false;

    $menu_obj = get_term( $locations[$location], 'nav_menu' );

    return $menu_obj;
}
?>

потом

//if you after the menu the menu with a specific ID / Slug
//$menu_obj =wp_get_nav_menu_object($id_slug_or_name); 

//if you after the menu at a specific location
$menu_obj = wpse45700_get_menu_by_location($location); 

echo "<h3>".esc_html($menu_obj->name)."</h3>";
//Display menu here

Или вместо отображения html вы можете передать его как часть аргумента для атрибута items в wp_nav_menu.

Например, чтобы отобразить меню в месте «основной»:

$location = 'primary';
$menu_obj = wpse45700_get_menu_by_location($location ); 
wp_nav_menu( array('theme_location' => $location, 'items_wrap'=> '<h3>'.esc_html($menu_obj->name).'</h3><ul id=\"%1$s\" class=\"%2$s\">%3$s</ul>') ); 

1
Стивен, спасибо за отличный ответ. Извините, что я нуб, но не могли бы вы предоставить код для передачи HTML в качестве аргумента. Это решило бы все. Благодарность!
ЧС

Смотрите обновленный ответ: D
Стивен Харрис

4

замените идентификатор 4 ниже на идентификатор вашего меню. если вы не знаете идентификатор, перейдите на страницу меню администратора, щелкните правой кнопкой мыши на вкладке меню, для которого вы хотите отобразить заголовок, проверьте элемент, и идентификатор будет указан как ссылка меню = идентификатор в ссылке.

<?
$_menu_object = wp_get_nav_menu_object( 4 );
$nav_menu_selected_title = $_menu_object->name;
echo $nav_menu_selected_title;
?>

2

Ответ Стивена хорош. но я поставил это на шаг впереди:

<?php 
$location = 'footer_navigation3';
if (has_nav_menu($location)) :
    $menu_obj = get_menu_by_location($location); 
    wp_nav_menu( array( 
        'theme_location'  => $location,
        'items_wrap'=> '<strong>'.esc_html($menu_obj->name).'</strong><ul id="%1$s" class="%2$s">%3$s</ul>'
    )); 
endif;
?>

при условии, что у вас есть зарегистрированное местоположение темы с именем "footer_navigation3" и назначено для него меню wp. Теперь разместите этот код там, где вы хотите отобразить свое меню.

Используя наш сайт, вы подтверждаете, что прочитали и поняли нашу Политику в отношении файлов cookie и Политику конфиденциальности.
Licensed under cc by-sa 3.0 with attribution required.