WordPress: wp_nav_menu personalizado para un menú específico

1 minuto de lectura

avatar de usuario
usuario3160134

Tengo un menú llamado “menú de encabezado” y solo quiero que este menú se vea afectado por la función que escribí a continuación. ¿Cómo puedo evitar que otros menús se vean afectados?

El script se llama así en header.php

<?php
wp_nav_menu(array('theme_location' => 'header-menu'); 
?>

en functions.php quiero que este filtro sea consciente cuando está manejando ‘menú de encabezado’

<?php
add_filter( 'wp_nav_menu_objects', 'my_menu_filter' );
function my_menu_filter( $items ) {
    $i = 0;
    foreach ( $items as $item )
    {
        if($i == 6)
            $item->title="<div id="end">.$item->title.</div>";
        else
            $item->title="<div class="link">.$item->title."</div>';
        $i++;
    }
    return $items;
}
?>

avatar de usuario
usuario3160134

Encontré la respuesta a mi propia pregunta:

add_filter( 'wp_nav_menu_objects', 'my_menu_filter', 10, 2);
function my_menu_filter( $items, $args ) {
    if($args->theme_location == "header-menu")
    {
        $i = 0;
        foreach ( $items as $item )
        {
            if($i == 6)
                $item->title="<div id="end">" . $item->title . '</div>';
            else
                $item->title="<div class="link">" .$item->title.'</div>';
            $i++;
        }
    }
    return $items;
}

La respuesta fue el cuarto argumento de add_filter que permite pasar un segundo objeto. Para verificar contra sentencias condicionales.

¿Ha sido útil esta solución?