您的浏览器过于古老 & 陈旧。为了更好的访问体验, 请 升级你的浏览器
Ready 发布于2013年03月23日 06:38

原创 WordPress实现面包屑导航

2849 次浏览 读完需要≈ 4 分钟 PHP

内容目录

最近考虑为本网站添加WordPress面包屑导航,希望实现的效果如下:

#如果是一级栏目页面(is_category),显示为:
当前位置: 首页 > 栏目名称 > 文章列表

#如果是多级栏目页面,显示为:
当前位置: 首页 > 一级栏目名称 > 二级栏目名称 > 文章列表

#如果是文章页面(is_single),显示为:
当前位置: 首页 > 栏目名称(支持多级栏目) > 文章标题
[object Object]
#如果是自定义页面(is_page),显示为:
当前位置: 首页 > 页面标题

废话不多说,直接上代码:

/**
 * 面包屑导航,直接输出(echo)
 * Breadcrumb Trail
 * @param string $sep 导航对象分隔符,默认为' > '
 */
function bread_nav($sep = ' > '){
    echo '<div>当前位置: <a href="'. home_url() .'" title="首页">首页</a>';
    if ( is_category() ){    //如果是栏目页面
        global $cat;        
        echo $sep . get_category_parents($cat, true, $sep) . '文章列表';
    }elseif ( is_page() ){    //如果是自定义页面
        echo $sep . get_the_title();
    }elseif ( is_single() ){    //如果是文章页面
        $categories = get_the_category();
        $cat = $categories[0];
        echo $sep . get_category_parents($cat->term_id, true, $sep) . get_the_title(); 
    }
    echo '</div>';
}

将以上代码直接添加到WordPress当前使用主题下的functions.php文件中。 然后在需要显示面包屑导航的地方(例如category.phpcontent-single.phpcontent-page.php等)直接如下调用即可。

<?php 
bread_nav();
?>

本站的WordPress面包屑导航默认使用一个>作为分隔符,你可以在调用的时候自行更改为>>或其他分隔符,例如:

<?php 
bread_nav('>>');
?>

面包屑导航实际效果可以参考本网站。

  • CodePlayer技术交流群1
  • CodePlayer技术交流群2

0 条评论

撰写评论