Como faço para gerar um sistema de menu / submenu personalizado usando wp_get_nav_menu_items no wordpress?
Eu tenho uma estrutura html que requer personalização dowp_nav_menu
código.
Este é o html que preciso gerar:
<ul class="main-nav">
<li class="item">
<a href="http://example.com/?p=123" class="title">Title</a>
<a href="http://example.com/?p=123" class="desc">Description</a>
<ul class="sub-menu">
<li class="item">
<a href="http://example.com/?p=123" class="title">Title</a>
<a href="http://example.com/?p=123" class="desc">Description</a>
</li>
</ul>
</li>
<li class="item">
<a href="http://example.com/?p=123" class="title">Title</a>
<a href="http://example.com/?p=123" class="desc">Description</a>
</li>
</ul>
Eu estou usando atualmentewp_get_nav_menu_items
para obter todos os itens do meu menu como uma matriz.
Agora eu sou capaz de gerar o html acimasem os submenus usando o seguinte código:
<?php
$menu_name = 'main-nav';
$locations = get_nav_menu_locations()
$menu = wp_get_nav_menu_object( $locations[ $menu_name ] );
$menuitems = wp_get_nav_menu_items( $menu->term_id, array( 'order' => 'DESC' ) );
foreach ( $menuitems as $item ):
$id = get_post_meta( $item->ID, '_menu_item_object_id', true );
$page = get_page( $id );
$link = get_page_link( $id ); ?>
<li class="item">
<a href="<?php echo $link; ?>" class="title">
<?php echo $page->post_title; ?>
</a>
<a href="<?php echo $link; ?>" class="desc">
<?php echo $page->post_excerpt; ?>
</a>
</li>
<?php endforeach; ?>
Eu teria gerado o menu usando owp_nav_menu
função, mas eu ainda preciso da descrição mostrada usando$page->post_excerpt
.
Eu descobri que existe uma propriedade para cada item chamado$item->menu_item_parent
que dá o ID do item de menu pai.
Como eu geraria o submenu no meuforeach
loop? Ou existe uma maneira realmente simples de usarwp_nav_menu
que o Google esqueceu de mencionar?