首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Wordpress NAV Walker未显示

Wordpress NAV Walker未显示
EN

Stack Overflow用户
提问于 2012-05-12 01:56:55
回答 2查看 2.6K关注 0票数 0

我有一个自定义的wordpress主题,我为导航实现了一个自定义的walker。

在我的functions.php中,我有这样的代码

代码语言:javascript
复制
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 = ' class="' . esc_attr( $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 .= '<br /><span class="sub">' . $item->description . '</span>';
            $item_output .= '</a>';
            $item_output .= $args->after;

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

在我的header.php中

代码语言:javascript
复制
<div id="access">
    <?php
    wp_nav_menu( array(
        'theme_location' => 'primary',
         'walker'=> new My_Walker
    ));
    ?>
</div>

但是当我查看我的页面源代码时,元素中没有数据

代码语言:javascript
复制
<div id="access">
            <div class="menu"><ul><li id="menu-item-5" class=""><a><br /><span class="sub"></span></a></li><li id="menu-item-8" class=""><a><br /><span class="sub"></span></a></li><li id="menu-item-10" class=""><a><br /><span class="sub"></span></a></li><li id="menu-item-13" class=""><a><br /><span class="sub"></span></a></li><li id="menu-item-15" class=""><a><br /><span class="sub"></span></a></li><li id="menu-item-17" class=""><a><br /><span class="sub"></span></a></li></ul></div>
        </div>

这应该是一个简单的步行器,但我不能让它工作

EN

回答 2

Stack Overflow用户

发布于 2012-05-12 02:52:14

更改:

代码语言:javascript
复制
'walker'=> new My_Walker

至:

代码语言:javascript
复制
'walker'=> new My_Walker()
票数 1
EN

Stack Overflow用户

发布于 2014-06-04 19:52:54

因为我是在开发区域中尝试的,所以我只有一个例子--我想要在nav_menu中有一个链接。有趣的是,walker函数会触发,并获取博客中所有页面的ID。但是$item->title为空。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/10556321

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档