私は私がwp_nav_menuを使用してちょうどうまく呼べるカスタムメニューを持っています。メニューの前にメニュー名をh3タグの内側に表示する方法はありますか?
例.
<h3>My Menu Name</h3>
<nav>
<ul>
<li>Menu Item 1</li>
<li>Menu Item 2</li>
</ul>
</nav>
あなたがメニューのスラッグを知っていれば、そして事はより簡単です、そうでなければあなたは指定された位置でメニューを得るためにこの関数を使うことができます。
<?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をエコーするのではなく、 wp_nav_menu
のitems属性の引数の一部として渡すこともできます。
たとえば、 'primary'の位置にメニューを表示するには、次のようにします。
$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>') );
下のID 4をあなたのメニューのIDに置き換えてください。 IDが管理者のメニューページに入っていない場合は、タイトルを表示したいメニューのタブを右クリックしてelemenentを調べると、IDがリンクにmenu = IDとして表示されます。
<?
$_menu_object = wp_get_nav_menu_object( 4 );
$nav_menu_selected_title = $_menu_object->name;
echo $nav_menu_selected_title;
?>
スティーブンの答えは良いです。しかし、私はそれをもう一歩進めます。
<?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メニューを割り当てたと仮定します。今すぐあなたのメニューを表示したいところにこのコードを置きなさい。