Я использую пользовательскую функцию ходунка для вывода структуры моего меню. Вот эта функция:
//custom menu walker
class CSS_Menu_Walker extends Walker {
//builds the structure
private $curItemID;
var $db_fields = array('parent' => 'menu_item_parent', 'id' => 'db_id');
function start_lvl(&$output, $depth = 0, $args = array()) {
$itemID = $this->curItemID;
$indent = str_repeat("\t", $depth);
$output .= "\n$indent<div id=\"dropdown".esc_attr($itemID)."\" class=\"dd_menu\" ><ul class=\"dd_list\">\n";
}
function end_lvl(&$output, $depth = 0, $args = array()) {
$indent = str_repeat("\t", $depth);
$output .= "$indent</ul></div>\n";
}
function start_el(&$output, $item, $depth = 0, $args = array(), $id = 0) {
global $wp_query, $wpdb;
$this->curItemID = $item->ID;
$indent = ($depth) ? str_repeat("\t", $depth) : '';
$class_names = $value = '';
$classes = empty($item->classes) ? array() : (array) $item->classes;
/* Add active class */
if (in_array('current-menu-item', $classes)) {
$classes[] = 'active';
unset($classes['current-menu-item']);
}
/* Check for children */
$children = get_posts(array('post_type' => 'nav_menu_item', 'nopaging' => true, 'numberposts' => 1, 'meta_key' => '_menu_item_menu_item_parent', 'meta_value' => $item->ID));
if (!empty($children)) {
$classes[] = 'has-sub';
}
$class_names = join(' ', apply_filters('nav_menu_css_class', array_filter($classes), $item, $args));
$class_names = $class_names ? ' class="' . esc_attr($class_names) . '"' : '';
$id = apply_filters('nav_menu_item_id', 'menu-item-'. $item->ID, $item, $args);
$id = $id ? ' id="' . esc_attr($id) . '"' : '';
$output .= $indent . '<li' . $id . $value . $class_names .'>';
$attributes = ! empty($item->attr_title) ? ' title="' . esc_attr($item->attr_title) .'"' : '';
$attributes .= ! empty($item->target) ? ' target="' . esc_attr($item->target ) .'"' : '';
$attributes .= ! empty($item->xfn) ? ' rel="' . esc_attr($item->xfn ) .'"' : '';
$attributes .= ! empty($item->url) ? ' href="' . esc_attr($item->url ) .'"' : '';
$item_output = $args->before;
$item_output .= '<a'. $attributes .'>';
$item_output .= $args->link_before . apply_filters('the_title',
$item->title, $item->ID) . $args->link_after;
$item_output .= '</a>';
$item_output .= '<span class="sub">' . $item->description . '</span>';
$item_output .= $args->after;
$output .= apply_filters('walker_nav_menu_start_el', $item_output, $item, $depth, $args);
}
function end_el(&$output, $item, $depth = 0, $args = array()) {
$output .= "</li>\n";
}
}
Она выводит это (классы WP удалены для краткости):
<li id="menu-item-17" class="dd_parent">
<a href="#">Technology</a>
<div id="dropdown17" class="dd_menu">
<ul class="dd_list">
<li id="menu-item-42" class="dd_intro">
<a href="http://#">Technology</a>
<span class="sub">Lorem ipsum dolor</span>
</li>
<li id="menu-item-43" class="dd_link">
<a href="http://#">Resources</a>
<span class="sub">Lorem ipsum dolor</span>
</li>
<li id="menu-item-44" class="dd_link">
<a href="http://#">Other</a>
<span class="sub">Lorem ipsum dolor</span>
</li>
</ul>
</div>
</li>
Что я хотел бы сделать, это сделать так, чтобы разметка вывода была такой:
<li id="menu-item-17" class="dd_parent">
<a href="#">Technology</a>
<div id="dropdown17" class="dd_menu">
<ul class="left">
<li id="menu-item-42" class="dd_intro">
<a href="http://#">Technology</a>
<span class="sub">Lorem ipsum dolor</span>
</li>
</ul>
<ul class="right">
<li id="menu-item-43" class="dd_link">
<a href="http://#">Resources</a>
<span class="sub">Lorem ipsum dolor</span>
</li>
<li id="menu-item-44" class="dd_link">
<a href="http://#">Other</a>
<span class="sub">Lorem ipsum dolor</span>
</li>
</ul>
</div>
</li>
в основном найдите класс li "dd_intro" и оберните его в класс ul "left", а затем найдите все классы li "dd_link" и оберните их в класс ul "right".