我想创建一个菜单,仅提取特定页面的子菜单选项。
例如,如果菜单选项DASHBOARD具有子菜单MESSAGE BOARD和CALENDAR,我希望能够创建一个仅包含MESSAGE BOARD和CALENDAR的单独菜单。
我想在没有wp_list_pages功能的情况下执行此操作,以便可以使用Appearances>管理菜单选项。 WordPress中的菜单选项卡。
谢谢!
答案 0 :(得分:1)
如果我理解正确,你想要子页面的附加菜单项吗?
即。你有一个看起来像这样的菜单
主页关于仪表板常见问题联系
DASHBOARD有2个子页面 - >董事会日历
当您在DASHBOARD页面上时,您希望BOARD和CALENDAR页面显示如下:
首页关于DASHBOAR常见问题联系我们 董事会日历
您可以在functions.php中添加一个aditional菜单,如下所示
<?php if (function_exists('register_nav_menus'))
{
register_nav_menus
(
array
(
'main_nav'=>'main menu', // your main menu
'dash_nav'=>'dashboard menu', //your dashboard menu
)
);
}?>
然后为仪表板创建一个页面模板:
<?php wp_nav_menu(array('menu'=>'dashboard menu'));?>
编辑:
你可以编辑header.php并添加类似这样的东西
<?php if (is_page_template('dashboard.php') :?>
<link href="csspath" rel="stylesheet" type="text/css" />
<?php endif;?>
这样你就可以添加另一个覆盖子菜单的css文件。
答案 1 :(得分:0)
我认为我有一个类似的愿望,你选择并只显示一个子菜单只是现有wordpress菜单中的子菜单项。这可以通过编辑functions.php并添加一个包含自己的walker类的短代码来定位并显示子菜单来完成。
//register menu shortcode
add_shortcode('menu', 'shortcode_menu');
function shortcode_menu($args ) {
//don't echo the ouput so we can return it
$args['echo']=false;
//in case menu isn't found display a message
$args['fallback_cb']='shortcode_menu_fallback';
//check if showing a submenu, if so make sure everything is setup to do so
if (isset($args['show_submenu']) && !empty($args['show_submenu'])) {
if (!isset($args['depth'])) {
$args['depth']=1;
}
$args['walker']=new Sub_Menu_Walker_Nav_Menu();
}
$menu=wp_nav_menu( $args );
return $menu;
}
//message to display if menu isn't found
function shortcode_menu_fallback($args ) {return 'No menu selected.';}
//special walker_nav_menu class to only display submenu
//depth must be greater than 0
//show_submenu specifies submenu to display
class Sub_Menu_Walker_Nav_Menu extends Walker_Nav_Menu {
function display_element( $element, &$children_elements, $max_depth, $depth=0, $args, &$output ) {
if ( !$element )
return;
$id_field = $this->db_fields['id'];
$displaythiselement=$depth!=0;
if ($displaythiselement) {
//display this element
if ( is_array( $args[0] ) )
$args[0]['has_children'] = ! empty( $children_elements[$element->$id_field] );
$cb_args = array_merge( array(&$output, $element, $depth), $args);
call_user_func_array(array(&$this, 'start_el'), $cb_args);
}
$id = $element->$id_field;
if ( is_array( $args[0] ) ){
$show_submenu=$args[0]['show_submenu'];
}else
$show_submenu=$args[0]->show_submenu;
// descend only when the depth is right and there are childrens for this element
if ( ($max_depth == 0 || $max_depth >= $depth+1 ) && isset( $children_elements[$id]) && $element->title==$show_submenu) {
foreach( $children_elements[ $id ] as $child ){
if ( !isset($newlevel) ) {
$newlevel = true;
//start the child delimiter
$cb_args = array_merge( array(&$output, $depth), $args);
call_user_func_array(array(&$this, 'start_lvl'), $cb_args);
}
$this->display_element( $child, $children_elements, $max_depth, $depth + 1, $args, $output );
}
unset( $children_elements[ $id ] );
}
if ( isset($newlevel) && $newlevel ){
//end the child delimiter
$cb_args = array_merge( array(&$output, $depth), $args);
call_user_func_array(array(&$this, 'end_lvl'), $cb_args);
}
if ($displaythiselement) {
//end this element
$cb_args = array_merge( array(&$output, $element, $depth), $args);
call_user_func_array(array(&$this, 'end_el'), $cb_args);
}
}
}
[menu menu='Main' show_submenu='About']
[menu menu='Main']
如需进一步阅读/参考,请参阅this wordpress question。
答案 2 :(得分:-1)
我很惊讶Wordpress没有在wp_nav_menu函数中内置此选项。在Wordpress中实现二级或分割菜单一直很困难。在尝试了许多不同的解决方案来实现这一目标后,我终于决定制作自己的插件,让您选择菜单的起始深度。因此,您只需将起始深度设置为&#39; 1&#39;用于二级菜单。
你使用这样的插件:
wp_nav_plus(array('theme_location' => 'primary_navigation', 'start_depth' => 1));
该插件可在我的网站上找到,感兴趣的是:https://mattkeys.me/products/wp-nav-plus/