Como removo UL em wp_nav_menu?

15

Eu pesquiso neste site e encontrei muitas respostas para essa pergunta. A maioria deles não está trabalhando no meu tema.

Aqui está uma solução que eu encontrado e está funcionando de acordo com a minha necessidade.

function wp_nav_menu_no_ul()
{
    $options = array(
        'echo' => false,
        'container' => false,
        'theme_location' => 'primary'
    );

    $menu = wp_nav_menu($options);
    echo preg_replace(array(
        '#^<ul[^>]*>#',
        '#</ul>$#'
    ), '', $menu);

}

Este código removerá ul no início e no final de wp_nav_menu() . Então, no meu tema eu apenas escrevo

<ul class="primary-nav">
<?php  wp_nav_menu_no_ul(); ?>
</ul>

Mas o problema está vindo de novo quando eu não adiciono ou ativo nenhum menu via admin. http://domain.com/wp-admin/nav-menus.php

Pergunta:

Como eu removo o <div><ul>**</ul></div> se o menu está ativo ou não. Me avise

Finalmente consegui que funcionasse :) functions.php

function wp_nav_menu_no_ul()
{
    $options = array(
        'echo' => false,
        'container' => false,
        'theme_location' => 'primary',
        'fallback_cb'=> 'default_page_menu'
    );

    $menu = wp_nav_menu($options);
    echo preg_replace(array(
        '#^<ul[^>]*>#',
        '#</ul>$#'
    ), '', $menu);

}

function default_page_menu() {
   wp_list_pages('title_li=');
} 

header.php

<ul class="primary-nav">
<?php  wp_nav_menu_no_ul(); ?>
</ul>
    
por haha 28.01.2011 / 09:32

5 respostas

10

A função wp_nav_menu usa um argumento de fallback_cb, que é o nome da função a ser executada se o menu não existir. então mude seu código para algo assim:

function wp_nav_menu_no_ul()
{
    $options = array(
        'echo' => false,
        'container' => false,
        'theme_location' => 'primary',
        'fallback_cb'=> 'fall_back_menu'
    );

    $menu = wp_nav_menu($options);
    echo preg_replace(array(
        '#^<ul[^>]*>#',
        '#</ul>$#'
    ), '', $menu);

}

function fall_back_menu(){
    return;
}

você pode até mesmo remover o container do menu e fazer outras coisas com mais argumentos enviados para a função wp_nav_menu

Espero que isso ajude.

    
por Bainternet 28.01.2011 / 10:07
49

Na verdade, o WordPress suporta isso por padrão:

wp_nav_menu(array(
    'items_wrap' => '%3$s'
));

O padrão para items_wrap é <ul id=\"%1$s\" class=\"%2$s\">%3$s</ul> .

    
por Martti Laine 07.12.2011 / 16:37
4

O código abaixo deve ser simples.

<?php 

  $my_menu = array( 
  'menu' => 'main-menu',
  'container' => '',
  'items_wrap' => '%3$s' 
  );

  wp_nav_menu( $my_menu );

?>

Consulte este link para a função wp_nav_menu enlace

    
por Dannamite 14.05.2014 / 10:06
2

Para mim, o que funcionou foi isto:

<?php wp_nav_menu( array(
       'container' => '',
       'items_wrap' => '%3$s' 
) ); ?>

Espero que ajude.

    
por Orbital Pixel 05.04.2014 / 22:58
2

Se você quiser imprimir apenas tags <a> , poderá seguir este caminho:

$primaryMenu = array(
    'theme_location'  => 'primary',
    'menu'            => '',
    'container'       => '',
    'container_class' => false,
    'container_id'    => '',
    'menu_class'      => 'menu',
    'menu_id'         => 'primary-menu',
    'echo'            => false,
    'fallback_cb'     => 'wp_page_menu',
    'before'          => '',
    'after'           => '',
    'link_before'     => '',
    'link_after'      => '',
    'depth'           => 0,
    'walker'          => ''
);
echo strip_tags( wp_nav_menu( $primaryMenu ), '<a>' );
    
por Pavlo Zamoroka 17.11.2015 / 08:02