仅限WordPress wp_nav_menu子菜单

时间:2012-07-06 02:38:16

标签: wordpress menu

我想创建一个菜单,仅提取特定页面的子菜单选项。

例如,如果菜单选项DASHBOARD具有子菜单MESSAGE BOARD和CALENDAR,我希望能够创建一个仅包含MESSAGE BOARD和CALENDAR的单独菜单。

我想在没有wp_list_pages功能的情况下执行此操作,以便可以使用Appearances>管理菜单选项。 WordPress中的菜单选项卡。

谢谢!

3 个答案:

答案 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类的短代码来定位并显示子菜单来完成。

“菜单”短代码和自定义菜单步行者类的PHP代码(全部在functions.php中):

    //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']

显示完整的“Main”菜单:

[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/