在菜单之间创建带有自定义徽标的WordPress页眉将菜单拆分为两个相等的部分

时间:2021-10-07 作者:Kevin Kenan

我想用创建Wordpress标题{the_custom_logo();} 菜单之间的自定义徽标将菜单拆分为两个相等的部分,以便徽标始终与页面中心对齐,其中菜单项的数量不是预先确定的。如下图所示enter image description here

,我正在寻找一种解决方案,避免创建两个不同的菜单,因为这将是一个模板的一部分,其中有许多可选择的标题,只有一个菜单,并且用户应该能够在菜单样式之间切换,而无需更改菜单内容,请帮助编写代码示例,代码示例将非常感谢,对我和未来的研究人员更有用!

1 个回复
最合适的回答,由SO网友:Buttered_Toast 整理而成

经过一些测试,我发现最好的方法是使用助行器。

对于本例,我们假设这是调用菜单的代码

wp_nav_menu([
    \'container\'        => false,
    \'theme_location\'   => \'right-side-top-menu\',
    \'walker\'           => new Menu_Middle_Logo()
]);
现在对于我们的walker来说,没有一种简单的方法来确定哪个父菜单项是中间的菜单项,但这段代码应该能够处理您的每个顶级菜单项场景。

class Menu_Middle_Logo extends Walker_Nav_Menu {
    function end_el (&$output, $item, $depth = 0, $args = [], $id = 0) {
        parent::end_el($output, $item, $depth, $args, $id);
        
        // the menu slug
        $theme_location = \'right-side-top-menu\';
        
        // check for top level depth and if correct menu
        if ($depth === 0 && isset($args->menu) && isset($args->menu->slug) && $args->menu->slug === $theme_location) {
            // get current menu items
            $menu_items = wp_get_nav_menu_items($theme_location);
            
            // will indicate how many top level menu items we have
            $parent_menu_items = [];
            
            // get top level menu items
            foreach ($menu_items as $menu_item) {
                if ($menu_item->menu_item_parent == 0) $parent_menu_items[] = $menu_item;
            }
            
            // get total menu items halved
            $half_menu_items = floor(count($parent_menu_items) / 2);
            
            // the menu item we want to add the logo to
            // before or after, depends if menu items are odd or even
            if (is_float($half_menu_items)) {
                // if you have odd menu items lets say three this will add after the first
                // [1] [custom html] [2] [3]
                // if you want it to add after the second remove the - 1, this will result in
                // [1] [2] [custom html] [3]
                $middle_item = $parent_menu_items[$half_menu_items - 1];
            } elseif (is_int($half_menu_items)) {
                // this handles even menu items
                $middle_item = $parent_menu_items[$half_menu_items - 1];
            }
            
            // if current menu item is middle item, add our custom html
            if (isset($middle_item) && $middle_item->ID === $item->ID) {
                $output .= \'<li class="my-logo">\';
                
                ob_start();
                the_custom_logo();
                // this is for testing because the_custom_logo()
                // is not available in my theme
                // echo 1234; 
                $output .= ob_get_clean();
                
                $output .= \'</li>\';
            }
        }
    }
}
将此walker代码复制到functions.php 它应该会起作用
别忘了在中添加walker属性wp_nav_menu args。

相关推荐

如何使用自定义Walker类将自定义分类术语动态添加为现有菜单项的子菜单

我有一个自定义的帖子类型,属于它,一个自定义的分类法。我试图让我的子主题动态地将属于该分类法的术语作为子菜单添加到主题菜单中某个列表项下。分类法是分层的,我想添加所有深度为1的术语,即具有适当缩进和与当前菜单相同样式的第一级和第二级术语。我的策略是,我首先想到了使用wp\\u nav\\u menu items过滤器,但由于可能有许多术语,而且它们是分层的,因此我认为最好使用自定义walker来扩展walker\\u nav\\u menu类。我遇到的问题是,当我尝试在自定义walker中调用get\\u