WordPress 3.0 – descriere meniu

Mazgalit de El July 4th, 2010

De cand cu lansarea wordpress 3.0, toata munca mea a fost mult mai usurata.Desigur ca am si inceput sa imi bag degetele prin el si deja am dat peste o mica problema. Cu toate ca avem optiunea “descriere” la meniu, nu avem nici un fel de documentatie (momentan cel putin) din care sa aflam cum sa o afisam.
Uitati si un exemplu sa intelegeti la ce ma refer cand spun “descriere a meniului”



Acum ca stiti despre ce e vb, haideti sa va si spun cum sa faceti:

Pentru cunoscatori in principiu trebuie folosita optiunea “Walker” in wp_nav_menu().

Deschideti fisierul function.php si introduceti acest cod

<?php
 
class My_Walker extends Walker_Nav_Menu
{
	function start_el(&$output, $item, $depth, $args) {
		global $wp_query;
		$indent = ( $depth ) ? str_repeat( "\t", $depth ) : '';
 
		$class_names = $value = '';
 
		$classes = empty( $item->classes ) ? array() : (array) $item->classes;
 
		$class_names = join( ' ', apply_filters( 'nav_menu_css_class', array_filter( $classes ), $item ) );
		$class_names = ' class="' . esc_attr( $class_names ) . '"';
 
		$output .= $indent . '<li id="menu-item-'. $item->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 .= '<br /><span class="sub">' . $item->description . '</span>';
		$item_output .= '</a>';
		$item_output .= $args->after;
 
		$output .= apply_filters( 'walker_nav_menu_start_el', $item_output, $item, $depth, $args );
	}
}

Dupa introducerea acestui cod, introduceti in header.php (sau unde aveti voi meniul introdus) si introduceti la inceput acest cod

$walker = new My_Walker;

, iar in interiorul array-ului pe acesta

'walker' => $walker

EX:

<?php
       $walker = new My_Walker;
	wp_nav_menu(array(
	        'echo' => true,
		'container' => '',
		'theme_location' => 'primary',
		'menu_class' => 'grid-10 omega',
		'walker' => $walker
	));
?>

Sper sa va fie lafel de folositor acest post cum mi-a fost si mie.


 

Lasa un comentariu