Deletes a navigation menu.
Parameters
-
$menuint | string | WP_Term required -
Menu ID, slug, name, or object.
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.