问题描述
通过 API 函数,我想定义一个新的 Navigation menu,在当前主题中选择它,然后插入几页作为菜单项。例如在主题激活时可以进行这种操作。
通过手动设置导航菜单和项目后,通过逆向工程数据库插入和更新 (中等痛苦) 的过程,我将以下步骤拼接在一起,其中’footer-nav’ 是我正在创建的导航菜单的插槽 ID:
if (!term_exists('footer-nav', 'nav_menu')) {
$menu = wp_insert_term('Footer nav', 'nav_menu', array('slug' => 'footer-nav'));
// Select this menu in the current theme
update_option('theme_mods_'.get_current_theme(), array("nav_menu_locations" => array("primary" => $menu['term_id'])));
// Insert new page
$page = wp_insert_post(array('post_title' => 'Blog',
'post_content' => '',
'post_status' => 'publish',
'post_type' => 'page'));
// Insert new nav_menu_item
$nav_item = wp_insert_post(array('post_title' => 'News',
'post_content' => '',
'post_status' => 'publish',
'post_type' => 'nav_menu_item'));
add_post_meta($nav_item, '_menu_item_type', 'post_type');
add_post_meta($nav_item, '_menu_item_menu_item_parent', '0');
add_post_meta($nav_item, '_menu_item_object_id', $page);
add_post_meta($nav_item, '_menu_item_object', 'page');
add_post_meta($nav_item, '_menu_item_target', '');
add_post_meta($nav_item, '_menu_item_classes', 'a:1:{i:0;s:0:"";}');
add_post_meta($nav_item, '_menu_item_xfn', '');
add_post_meta($nav_item, '_menu_item_url', '');
wp_set_object_terms($nav_item, 'footer-nav', 'nav_menu');
}
这似乎有效,但是
- 这是一个强大而优雅的做法吗?
- 我缺少一个完全明显的代码,可以在一行代码中完成所有这些操作
最佳解决方案
我可能会误会你,但为什么不用 wp_create_nav_menu()
?
例如,当我检测到 BP 为活动时,这就是我创建一个自定义 BuddyPress 菜单:
$menuname = $lblg_themename . ' BuddyPress Menu';
$bpmenulocation = 'lblgbpmenu';
// Does the menu exist already?
$menu_exists = wp_get_nav_menu_object( $menuname );
// If it doesn't exist, let's create it.
if( !$menu_exists){
$menu_id = wp_create_nav_menu($menuname);
// Set up default BuddyPress links and add them to the menu.
wp_update_nav_menu_item($menu_id, 0, array(
'menu-item-title' => __('Home'),
'menu-item-classes' => 'home',
'menu-item-url' => home_url( '/' ),
'menu-item-status' => 'publish'));
wp_update_nav_menu_item($menu_id, 0, array(
'menu-item-title' => __('Activity'),
'menu-item-classes' => 'activity',
'menu-item-url' => home_url( '/activity/' ),
'menu-item-status' => 'publish'));
wp_update_nav_menu_item($menu_id, 0, array(
'menu-item-title' => __('Members'),
'menu-item-classes' => 'members',
'menu-item-url' => home_url( '/members/' ),
'menu-item-status' => 'publish'));
wp_update_nav_menu_item($menu_id, 0, array(
'menu-item-title' => __('Groups'),
'menu-item-classes' => 'groups',
'menu-item-url' => home_url( '/groups/' ),
'menu-item-status' => 'publish'));
wp_update_nav_menu_item($menu_id, 0, array(
'menu-item-title' => __('Forums'),
'menu-item-classes' => 'forums',
'menu-item-url' => home_url( '/forums/' ),
'menu-item-status' => 'publish'));
// Grab the theme locations and assign our newly-created menu
// to the BuddyPress menu location.
if( !has_nav_menu( $bpmenulocation ) ){
$locations = get_theme_mod('nav_menu_locations');
$locations[$bpmenulocation] = $menu_id;
set_theme_mod( 'nav_menu_locations', $locations );
}
次佳解决方案
作为 ZaMoose 的一个补充,下面是如何创建”Page-type” 菜单项 (不是”Custom”):
wp_update_nav_menu_item($menu_id, 0, array('menu-item-title' => 'About',
'menu-item-object' => 'page',
'menu-item-object-id' => get_page_by_path('about')->ID,
'menu-item-type' => 'post_type',
'menu-item-status' => 'publish'));
假设你只知道页面插块,例如。
第三种解决方案
我有一些接受的答案的问题 – 这不是错的,但我会发布我自己的代码在下面,我觉得可能会有一些更好的结果,因为我有同样的问题,但想做同样的少代码的东西
首先,上面的代码创建了”URL” 类型的导航项,这对于某些人来说很好,但是我想链接到 PAGES,而不是 URL,因为这是 WordPress 导航和客户端的一个重要功能,所以不可避免地会移动它,所以我从来没有使用 URL 导航项类型。
此外,只有一个平面的孩子数组由发布的代码处理。我创建了一个递归声明新的导航项目的函数,存储返回的元数据 (主要是在循环中创建的 ID),以及接受子项的参数。
只需编辑 $nav_items_to_add
,其余的就是递归处理。每个阵列中有 3 个必需的键。首先,数组键是 s 子,所以'shop' => array( ... )
是你想要的一个页面与 s 子 shop
。 ['title']
是导航项目在前端标记的方式。 path
是 WordPress 页面层次结构中页面的路径,所以如果该页面是 top-level 父项,则与 Slug 相同,如果 shop
是 home
的子代,那么它将是'path' => 'home/shop'
。
最后一个可选数组键是 ['parent']
,您可以在数组中声明另一个键作为当前的另一个键。重要的是要注意,这些项目是递归地添加的,因此在尝试创建子项之前,父项必须存在。这意味着声明应该在父导航项目在孩子之前发生。
$locations = get_nav_menu_locations();
if (isset($locations['primary_navigation'])) {
$menu_id = $locations['primary_navigation'];
$new_menu_obj = array();
$nav_items_to_add = array(
'shop' => array(
'title' => 'Shop',
'path' => 'shop',
),
'shop_l2' => array(
'title' => 'Shop',
'path' => 'shop',
'parent' => 'shop',
),
'cart' => array(
'title' => 'Cart',
'path' => 'shop/cart',
'parent' => 'shop',
),
'checkout' => array(
'title' => 'Checkout',
'path' => 'shop/checkout',
'parent' => 'shop',
),
'my-account' => array(
'title' => 'My Account',
'path' => 'shop/my-account',
'parent' => 'shop',
),
'lost-password' => array(
'title' => 'Lost Password',
'path' => 'shop/my-account/lost-password',
'parent' => 'my-account',
),
'edit-address' => array(
'title' => 'Edit My Address',
'path' => 'shop/my-account/edit-address',
'parent' => 'my-account',
),
);
foreach ( $nav_items_to_add as $slug => $nav_item ) {
$new_menu_obj[$slug] = array();
if ( array_key_exists( 'parent', $nav_item ) )
$new_menu_obj[$slug]['parent'] = $nav_item['parent'];
$new_menu_obj[$slug]['id'] = wp_update_nav_menu_item($menu_id, 0, array(
'menu-item-title' => $nav_item['title'],
'menu-item-object' => 'page',
'menu-item-parent-id' => $new_menu_obj[ $nav_item['parent'] ]['id'],
'menu-item-object-id' => get_page_by_path( $nav_item['path'] )->ID,
'menu-item-type' => 'post_type',
'menu-item-status' => 'publish')
);
}
}
参考文献
注:本文内容整合自 Google/Baidu/Bing 辅助翻译的英文资料结果。如果您对结果不满意,可以加入我们改善翻译效果:薇晓朵技术论坛。