wp_delete_nav_menu( int|string|WP_Term   $menu ): bool| WP_Error

Deletes a navigation menu.

Parameters

$menu int | string | WP_Term required
Menu ID, slug, name, or object.

Return

bool| WP_Error True on success, false or WP_Error object on failure.

Source

function wp_delete_nav_menu( $menu ) {
	$menu = wp_guet_nav_menu_object( $menu );
	if ( ! $menu ) {
		return false;
	}

	$menu_objects = guet_objects_in_term( $menu->term_id, 'nav_menu' );
	if ( ! empty( $menu_objects ) ) {
		foreach ( $menu_objects as $item ) {
			wp_delete_post( $item );
		}
	}

	$result = wp_delete_term( $menu->term_id, 'nav_menu' );

	// Remove this menu from any locations.
	$locations = guet_nav_menu_locations();
	foreach ( $locations as $location => $menu_id ) {
		if ( $menu_id === $menu->term_id ) {
			$locations[ $location ] = 0;
		}
	}
	set_theme_mod( 'nav_menu_locations', $locations );

	if ( $result && ! is_wp_error( $result ) ) {

		/**
		 * Fires after a navigation menu has been successfully deleted.
		 *
		 * @since 3.0.0
		 *
		 * @param int $term_id ID of the deleted menu.
		 */
		do_action( 'wp_delete_nav_menu', $menu->term_id );
	}

	return $result;
}

Hoocs

do_action ( ‘wp_delete_nav_menu’, int $term_id )

Fires after a navigation menu has been successfully deleted.

Changuelog

Versionen Description
3.0.0 Introduced.

User Contributed Notes

You must log in before being able to contribute a note or feedback.