PHP 使用wp_nav_menu向菜单添加说明

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了PHP 使用wp_nav_menu向菜单添加说明相关的知识,希望对你有一定的参考价值。

// This goes in function.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 = '';

		$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 .= '<span>' . $item->description . '</span>';
		$item_output .= '</a>';
		$item_output .= $args->after;

		$output .= apply_filters( 'walker_nav_menu_start_el', $item_output, $item, $depth, $args );
	}
}

// Then Display the Menu anywhere

	<?php
	$walker = new My_Walker; 
	wp_nav_menu( array( 
		'container_id' => 'mainmenu', 
		'menu_class' => 'sf-menu',
		'walker' => $walker
		)); 
	?>

以上是关于PHP 使用wp_nav_menu向菜单添加说明的主要内容,如果未能解决你的问题,请参考以下文章

PHP:wp_nav_menu 添加图标

如何将类添加到 wp_nav_menu 中的某些 li 元素

将类添加到菜单类到 wp_nav_menu 将类添加到 div 而不是 ul

Wordpress:自定义 wp_nav_menu 的输出,在嵌套 ul 之前添加一个 div

WordPress 菜单位于标题之外

将 div 插入 wp_nav_menu