Answers:
start_el()
应该在其$args
参数中获取此信息,但似乎WordPress仅在$args
为array时填充此信息,而对于自定义导航菜单,它是一个对象。这是在Trac票中报告的。没问题,如果您还重写display_element()
自定义walker中的方法,则可以自己填写(因为这是访问子元素数组的最简单位置):
class WPSE16818_Walker extends Walker_Nav_Menu
{
function display_element( $element, &$children_elements, $max_depth, $depth=0, $args, &$output )
{
$id_field = $this->db_fields['id'];
if ( is_object( $args[0] ) ) {
$args[0]->has_children = ! empty( $children_elements[$element->$id_field] );
}
return parent::display_element( $element, $children_elements, $max_depth, $depth, $args, $output );
}
function start_el( &$output, $item, $depth, $args ) {
if ( $args->has_children ) {
// ...
}
}
更新:从WordPress 3.7(2013年10月)开始,已添加CSS类以指示主题菜单中的子菜单项和页面-无需使用自定义的walker,因为它已在WordPress核心中得到了照顾。
CSS类的名称为menu-item-has-children
和page_item_has_children
。
有关匆忙中任何人的完整解决方案(请参见Jan Fabry的先前答案),请参见下面的完整实现。
在主题模板中输出导航:
wp_nav_menu( array(
'theme_location' => 'navigation-primary',
'container' => false,
'container_class' => '',
'container_id' => '',
'menu_class' => '',
'menu_id' => '',
'walker' => new Selective_Walker(),
'depth' => 2
)
);
然后,在主题中添加以下内容functions.php
:
class Selective_Walker extends Walker_Nav_Menu {
function display_element( $element, &$children_elements, $max_depth, $depth=0, $args, &$output ) {
$id_field = $this->db_fields['id'];
if ( is_object( $args[0] ) ) {
$args[0]->has_children = !empty( $children_elements[$element->$id_field] );
}
return parent::display_element( $element, $children_elements, $max_depth, $depth, $args, $output );
}
function start_el( &$output, $item, $depth, $args ) {
if ( $args->has_children ) {
$item->classes[] = 'has_children';
}
parent::start_el(&$output, $item, $depth, $args);
}
}
结果HTML输出类似于以下内容:
<ul>
<li><a href="#">Home</a></li>
<li class="has_children"><a href="#">About</a>
<ul class="sub-menu">
<li><a href="#">Our Mission</a></li>
</ul>
</li>
<li><a href="#">Services</a></li>
<li class="has_children"><a href="#">Products</a>
<ul class="sub-menu">
<li><a href="#">Lorem Ipsum</a></li>
<li><a href="#">Lorem Ipsum</a></li>
</ul>
</li>
<li><a href="#">Contact Us</a></li>
</ul>
有关使用WordPress的沃克类的更多信息,请参阅了解沃克类。
请享用!
该功能正是您想要的。它还向您展示了一种修改导航菜单项的非常有效的方法。此外,您可以通过item-filter打开它以使用更高级的功能(例如,子主题):
/**
* Classes for a navigation named "Topnav" in the nav location "top".
* Shows examples on how to modify the current nav menu item
*
* @param (object) $items
* @param (object) $menu
* @param (object) $args
*/
function wpse16818_nav_menu_items( $items, $menu, $args )
{
# >>>> start editing
// examples for possible targets
$target['name'] = 'Topnav';
// The targeted menu item/s
$target['items'] = array( (int) 6 );
# <<<< stop editing
// filter for child themes: "config_nav_menu_topnav"
$target = apply_filters( 'config_nav_menu_'.strtolower( $target['name'] ), $target );
// Abort if we're not with the named menu
if ( $menu->name !== $target['name'] )
return;
foreach ( $items as $item )
{
// Check what $item contains
echo '<pre>'; print_r($item); echo '</pre>';
// First real world example:
$item->classes = 'span-4';
// Second real world example:
// Append this class if we are in one of the targeted items
if ( in_array( (int) $item->menu_order, $target['items'] ) )
$item->classes .= ' last';
}
return $items;
}
add_filter( 'wp_get_nav_menu_items', 'wpse16818_nav_menu_items', 10, 3 );
是的,几乎在每种情况下,都不需要定制的助行器。
如果要下拉菜单,则只能使用CSS。与孩子一起在WP中自定义导航,WordPress会自动将class .sub-menu分配给孩子ul。试试这个CSS
nav li {position:relative;}
.sub-menu {display:none; position:absolute; width:300px;}
nav ul li:hover ul {display:block;}
您可能需要添加一些jQuery,以使其更加有趣,但这将为您提供一个有效的下拉菜单。