WP_NAV_MENU()|使用内置功能输出我自己的自定义代码

时间:2019-02-20 作者:Jason Is My Name

我使用以下方法创建了(WordPress更是如此):

<?php
wp_nav_menu( array(
    \'theme_location\' => \'primary-menu\',
    \'menu_id\'        => \'primary-menu\'
) );
?>
它输出:

<div id="primary-menu" class="menu">
    <ul aria-expanded="false" class=" nav-menu">
        <li class="page_item page-item-35"><a href="http://example.uk/blog/">Blog</a></li>
        <li class="page_item page-item-86 current_page_item"><a href="http://example.uk/">Home</a></li>
    </ul>
</div>
我要求它像这样输出(链接与应用自定义类的文本分离):

<div id="primary-menu" class="menu">
    <ul aria-expanded="false" class=" nav-menu">
        <li class="page_item page-item-35"><a class="box-link" href="http://example.uk/blog/"></a>Blog</li>
        <li class="page_item page-item-86 current_page_item"><a class="box-link" href="http://example.uk/"></a>Home</li>
    </ul>
</div>
我觉得这应该是可能的。请不要标记为重复,并发送给我其他地方,因为这是没有涵盖,你想从文本中分离的链接。我想我已经读过一篇文章,其中我可以应用自定义类。

谢谢你的关注,J。

1 个回复
SO网友:Jacob Peattie

导航菜单链接的构造由start_el() 的方法Walker_Nav_Menu 班可以通过扩展Walker_Nav_Menu 并替换start_el() 使用自己的方法。然后,您可以通过设置walker 的参数wp_nav_menu().

因此,第一步是创建一个新类(我们称之为Box_Link_Walker), 以及整个start_el() 的方法Walker_Nav_Menu 其中(我删除了原始方法的所有内联文档,以节省此答案中的空间):

class Box_Link_Walker extends Walker_Nav_Menu {
    public function start_el( &$output, $item, $depth = 0, $args = array(), $id = 0 ) {
        if ( isset( $args->item_spacing ) && \'discard\' === $args->item_spacing ) {
            $t = \'\';
            $n = \'\';
        } else {
            $t = "\\t";
            $n = "\\n";
        }
        $indent = ( $depth ) ? str_repeat( $t, $depth ) : \'\';

        $classes = empty( $item->classes ) ? array() : (array) $item->classes;
        $classes[] = \'menu-item-\' . $item->ID;

        $args = apply_filters( \'nav_menu_item_args\', $args, $item, $depth );

        $class_names = join( \' \', apply_filters( \'nav_menu_css_class\', array_filter( $classes ), $item, $args, $depth ) );
        $class_names = $class_names ? \' class="\' . esc_attr( $class_names ) . \'"\' : \'\';

        $id = apply_filters( \'nav_menu_item_id\', \'menu-item-\'. $item->ID, $item, $args, $depth );
        $id = $id ? \' id="\' . esc_attr( $id ) . \'"\' : \'\';

        $output .= $indent . \'<li\' . $id . $class_names .\'>\';

        $atts = array();
        $atts[\'title\']  = ! empty( $item->attr_title ) ? $item->attr_title : \'\';
        $atts[\'target\'] = ! empty( $item->target )     ? $item->target     : \'\';
        $atts[\'rel\']    = ! empty( $item->xfn )        ? $item->xfn        : \'\';
        $atts[\'href\']   = ! empty( $item->url )        ? $item->url        : \'\';

        $atts = apply_filters( \'nav_menu_link_attributes\', $atts, $item, $args, $depth );

        $attributes = \'\';
        foreach ( $atts as $attr => $value ) {
            if ( ! empty( $value ) ) {
                $value = ( \'href\' === $attr ) ? esc_url( $value ) : esc_attr( $value );
                $attributes .= \' \' . $attr . \'="\' . $value . \'"\';
            }
        }

        $title = apply_filters( \'the_title\', $item->title, $item->ID );

        $title = apply_filters( \'nav_menu_item_title\', $title, $item, $args, $depth );

        $item_output = $args->before;
        $item_output .= \'<a\'. $attributes .\'>\';
        $item_output .= $args->link_before . $title . $args->link_after;
        $item_output .= \'</a>\';
        $item_output .= $args->after;

        $output .= apply_filters( \'walker_nav_menu_start_el\', $item_output, $item, $depth, $args );
    }
}
我们唯一需要担心的是这一部分:

$atts[\'title\']  = ! empty( $item->attr_title ) ? $item->attr_title : \'\';
$atts[\'target\'] = ! empty( $item->target )     ? $item->target     : \'\';
$atts[\'rel\']    = ! empty( $item->xfn )        ? $item->xfn        : \'\';
$atts[\'href\']   = ! empty( $item->url )        ? $item->url        : \'\';
您只需添加一行即可添加box-link 锚元素的类别:

$atts[\'class\']  = \'box-link\';
本节:

$item_output = $args->before;
$item_output .= \'<a\'. $attributes .\'>\';
$item_output .= $args->link_before . $title . $args->link_after;
$item_output .= \'</a>\';
$item_output .= $args->after;
只需重新排列即可将标题移到锚元素之外:

$item_output = $args->before;
$item_output .= \'<a\'. $attributes .\'>\';
$item_output .= \'</a>\';
$item_output .= $args->link_before . $title . $args->link_after;
$item_output .= $args->after;
现在,您可以通过设置walker 的参数wp_nav_menu():

wp_nav_menu( array(
    \'theme_location\' => \'primary-menu\',
    \'menu_id\'        => \'primary-menu\',
    \'walker\'         => new Box_Link_Walker(),
) );
顺便说一句,我觉得我应该指出,以这种方式构建链接对可访问性有害,对于屏幕阅读器和搜索引擎机器人来说,链接似乎没有标签。我建议不要实施这一点。无论您尝试应用何种CSS效果,几乎可以肯定,都不会破坏链接的可访问性。

相关推荐

用标准的干净文件替换NAV-menus.php文件?

我是一个自学成才的wordpress网站设计师,请原谅我的无知。我为一个客户开发的几个网站最近被一个印尼黑客组织破坏了(很有趣!)。客户端没有更新wordpress安装和其他一些危及安全的事情。遗憾的是,没有网站的清理备份。网络主机给了我一个包含恶意软件扫描结果的文本文件。看起来很多受影响的文件都是导航菜单。网站的php文件。文本文件中显示的扫描结果示例如下:“[主目录]/[网站文件夹名称]/wp includes/nav-menu.php:SL-php-INJECTOR-1-ejw.UNOFFICIAL