muestra la ruta de navegación actual desde el menú

4

Quiero algo como esto

Inicio > Productos > Acero > Uñas

¡Esta información debe venir de la estructura del menú! Instalé Breadcrumb NavXT pero parece que solo toma la ruta que definí (esta es la principal y así sucesivamente). Pero necesito esto de la estructura del menú no del usuario. ¿Tengo que configurar la página principal para cada página o hay alguna solución que lea la jerarquía de mi menú? No encontré un Breadcrumb NavXT y parece que tengo que escribir un script PHP para eso.

Editar:

Para mi siguiente pregunta, agregué el siguiente código:

if(in_array('current-menu-item', $item->classes)){
    $attributes .= ' class="active"';
}
    
pregunta testing 27.04.2012 - 14:28

1 respuesta

5

La mejor manera sería usar wp_nav_menu con un caminante personalizado.

Requisitos previos:

Useage

Donde quiera que desee las rutas de navegación ( para la ubicación del tema 'principal' ):

<?php wp_nav_menu( array( 
    'container' => 'none', 
    'theme_location' => 'primary',
    'walker'=> new SH_BreadCrumbWalker, 
    'items_wrap' => '<div id="breadcrumb-%1$s" class="%2$s">%3$s</div>'
 ) ); ?>

El caminante personalizado

Esto es muy básico . (Esto se podría hacer de otra manera, ¿anular a display_element en su lugar? - pero encontré que esto es lo más sencillo). Esto debería vivir en tu functions.php

class SH_BreadCrumbWalker extends Walker{
    /**
     * @see Walker::$tree_type
     * @var string
     */
    var $tree_type = array( 'post_type', 'taxonomy', 'custom' );

    /**
     * @see Walker::$db_fields
     * @var array
     */
    var $db_fields = array( 'parent' => 'menu_item_parent', 'id' => 'db_id' );

    /**
     * delimiter for crumbs
     * @var string
     */
    var $delimiter = ' > ';

    /**
     * @see Walker::start_el()
     *
     * @param string $output Passed by reference. Used to append additional content.
     * @param object $item Menu item data object.
     * @param int $depth Depth of menu item.
     * @param int $current_page Menu item ID.
     * @param object $args
     */
    function start_el(&$output, $item, $depth, $args) {

        //Check if menu item is an ancestor of the current page
        $classes = empty( $item->classes ) ? array() : (array) $item->classes;
        $current_identifiers = array( 'current-menu-item', 'current-menu-parent', 'current-menu-ancestor' ); 
        $ancestor_of_current = array_intersect( $current_identifiers, $classes );     


        if( $ancestor_of_current ){
            $title = apply_filters( 'the_title', $item->title, $item->ID );

            //Preceed with delimter for all but the first item.
            if( 0 != $depth )
                $output .= $this->delimiter;

            //Link tag attributes
            $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        ) .'"' : '';

            //Add to the HTML output
            $output .= '<a'. $attributes .'>'.$title.'</a>';
        }
    }
}
    
respondido por el Stephen Harris 27.04.2012 - 16:12

Lea otras preguntas en las etiquetas