リンクタイトルに、説明文を付けたいという質問があったので、以下のように答えてみました。
functions.php
<?php class MyWalker extends Walker_Nav_Menu{ function start_el( &$output, $item, $depth= 0, $args= array(), $id= 0 ) { global $wp_query; $indent= ( $depth ) ? str_repeat( "\t", $depth ) : ''; $class_names= $value= ''; $classes= empty( $item->classes ) ? array() : (array) $item->classes; $classes[]= 'menu-item-' . $item->ID; $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>'.$item->description.'</span>'; $item_output .= $args->after; $output .= apply_filters( 'walker_nav_menu_start_el', $item_output, $item, $depth, $args ); } }?>
template.php
$MyWalker= new MyWalker(); $args= array('walker'=> $MyWalker); wp_nav_menu( array('walker'=> $MyWalker, 'container_class'=> 'menu-header', 'theme_location'=> 'primary')); ?> http://ja.forums.wordpress.org/topic/10476?replies=5(b:title)
第2案は以下
<?php add_filter( 'walker_nav_menu_start_el', 'my_test' ,10,4); function my_test($item_output,$item,$depth,$args){ return $item_output .'<span>'.$item->description.'</span>'; } ?>
nav_menu_css_class も ついている 便利だ。
残念だけれども、これらの事に気がついたのは、その質問があったからだった