问题描述
我已经搞砸了几个小时,仍然无法让这个工作,所以我终于放弃了并寻求一些帮助。
我正在尝试编写一个只显示当前页面的自定义步行者,或者没有孩子显示页面的兄弟姐妹。
例如,选择以下菜单树:
-
1.0
-
1.2.0
-
1.3.0
-
1.3.1
-
1.3.2
-
-
1.2.1
-
1.2.2
-
-
2.0
我们假设我在当前页面 1.2.0 。在这个页面上,我想显示它的孩子 (1.3.0,1.3.1,1.3.2)
但是,如果我在页面 1.2.2,因为它没有任何孩子,它应该显示它是当前级别的兄弟姐妹,所以它应该显示我 (1.2.0,1.2.1,1.2.2) 。
最佳解决方案
这是我以前只显示当前菜单项的孩子的步行者。或者菜单项兄弟姐妹如果没有自己的孩子。
整个课程都有评论解释每个部分
<?php
class SH_Child_Only_Walker extends Walker_Nav_Menu {
private $ID;
private $depth;
private $classes = array();
private $child_count = 0;
private $have_current = false;
// Don't start the top level
function start_lvl(&$output, $depth=0, $args=array()) {
if( 0 == $depth || $this->depth != $depth )
return;
parent::start_lvl($output, $depth,$args);
}
// Don't end the top level
function end_lvl(&$output, $depth=0, $args=array()) {
if( 0 == $depth || $this->depth != $depth )
return;
parent::end_lvl($output, $depth,$args);
}
// Don't print top-level elements
function start_el(&$output, $item, $depth=0, $args=array()) {
$is_current = in_array('current-menu-item', $this->classes);
if( 0 == $depth || ! $is_current )
return;
parent::start_el($output, $item, $depth, $args);
}
function end_el(&$output, $item, $depth=0, $args=array()) {
if( 0 == $depth )
return;
parent::end_el($output, $item, $depth, $args);
}
// Only follow down one branch
function display_element( $element, &$children_elements, $max_depth, $depth=0, $args, &$output ) {
// Check if element is in the current tree to display
$current_element_markers = array( 'current-menu-item', 'current-menu-parent', 'current-menu-ancestor' );
$this->classes = array_intersect( $current_element_markers, $element->classes );
// If element has a 'current' class, it is an ancestor of the current element
$ancestor_of_current = !empty($this->classes);
// check if the element is the actual page element we are on.
$is_current = in_array('current-menu-item', $this->classes);
// if it is the current element
if($is_current) {
// set the count / ID / and depth to use in the other functions.
$this->child_count = ( isset($children_elements[$element->ID]) ) ? count($children_elements[$element->ID]) : 0;
$this->ID = $element->ID;
$this->depth = $depth;
$this->have_current = true;
if($this->child_count > 0) {
// if there are children loop through them and display the kids.
foreach( $children_elements[$element->ID] as $child ) {
parent::display_element( $child, $children_elements, $max_depth, $depth, $args, $output );
}
} else {
// no children so loop through kids of parent item.
foreach( $children_elements[$element->menu_item_parent] as $child ) {
parent::display_element( $child, $children_elements, $max_depth, $depth, $args, $output );
}
}
}
// if depth is zero and not in current tree go to the next element
if ( 0 == $depth && !$ancestor_of_current)
return;
// if we aren't on the current element proceed as normal
if(! $this->have_current )
parent::display_element( $element, $children_elements, $max_depth, $depth, $args, $output );
}
}
像在 wp_nav_menu 上的任何其他自定义步行者一样添加它
<?php
wp_nav_menu( array(
'menu' => 'primary-menu'
,'container' => 'nav'
,'container_class' => 'subpages'
,'depth' => 0
,'walker' => new SH_Child_Only_Walker()
));
?>
参考文献
注:本文内容整合自 Google/Baidu/Bing 辅助翻译的英文资料结果。如果您对结果不满意,可以加入我们改善翻译效果:薇晓朵技术论坛。