Make WordPress Core

Opened 7 years ago

Last modified 5 months ago

#13910 reviewing feature request

Get Menu name with wp_nav_menu()

Reported by: jowo Owned by: chriscct7
Milestone: 4.8 Priority: normal
Severity: normal Version: 3.0
Component: Menus Keywords: has-patch dev-feedback has-unit-tests
Focuses: Cc:


There is no way to get the actual "Menu name" in wp_nav_menu()

For example if you want to create a left sidebar menu you want a header to go with it. In previous versions you could do use wp_list_pages() with "title_li".

With wp_nav_menu() you have to hard code <h3>Static menu name</h3> into the template before calling the function.

If you could get the "Menu name" as defined in backend interface from the wp_nav_menu() it would create the menu title automatically.

Attachments (3)

13910.diff (1.2 KB) - added by wojtek.szkutnik 7 years ago.
13910-2.diff (1.6 KB) - added by christophherr 12 months ago.
Turns markoheijnen's comment into a patch. Adds filter for the title of a navigation menu.
13910.tests.patch (892 bytes) - added by SpencerFinnell 5 months ago.
Add tests for wp_nav_menu_title()

Download all attachments as: .zip

Change History (16)

#1 @ocean90
7 years ago

  • Milestone changed from 3.0 to Future Release

#2 @pavelevap
7 years ago

  • Cc pavelevap@… added

#3 @wojtek.szkutnik
7 years ago

  • Cc wojtek.szkutnik@… added
  • Keywords has-patch needs-testing added; wp_nav_menu menu name removed

#4 @wojtek.szkutnik
7 years ago

  • Keywords gsoc added

#5 @dangayle
6 years ago

+1 I've needed this a few times, having to resort to a similar solution to http://www.wptavern.com/forum/themes-templates/1563-list-available-wp_nav_menus.html

#6 @markoheijnen
5 years ago

  • Cc marko@… added
  • Keywords dev-feedback added; gsoc removed

The patch looks wrong. title shouldn't be an argument and it should have been $menu->name.

Also a function like this should be in core

function wp_nav_menu_title( $theme_location ) {
	$title = '';
	if ( $theme_location && ( $locations = get_nav_menu_locations() ) && isset( $locations[ $theme_location ] ) ) {
		$menu = wp_get_nav_menu_object( $locations[ $theme_location ] );
		if( $menu && $menu->name ) {
			$title = $menu->name;

	return apply_filters( 'wp_nav_menu_title', $title, $theme_location );

#7 @DrewAPicture
5 years ago

  • Cc xoodrew@… added

#8 @chriscct7
20 months ago

There was about 10 comments from the same user that were moderated as spam (which I confirmed they were). Reviewed and deleted them.

This ticket was mentioned in Slack in #core by chriscct7. View the logs.

15 months ago

12 months ago

Turns markoheijnen's comment into a patch. Adds filter for the title of a navigation menu.

#10 @christophherr
12 months ago

  • Keywords needs-unit-tests added

Following what chriscct7 said in Slack, 13910-2.diff turns markoheijnen's comment into a patch.

5 months ago

Add tests for wp_nav_menu_title()

#11 @SpencerFinnell
5 months ago

  • Keywords has-unit-tests 4.8-early added; needs-testing needs-unit-tests removed

#12 @chriscct7
5 months ago

  • Keywords 4.8-early removed
  • Milestone changed from Future Release to 4.8

#13 @chriscct7
5 months ago

  • Owner set to chriscct7
  • Status changed from new to reviewing
Note: See TracTickets for help on using tickets.