最近考虑为本网站添加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.php、content-single.php、content-page.php等)直接如下调用即可。
<?php
bread_nav();
?>
本站的WordPress面包屑导航默认使用一个>
作为分隔符,你可以在调用的时候自行更改为>>
或其他分隔符,例如:
<?php
bread_nav('>>');
?>
原文:http://www.365mini.com/page/wordpress-breadcrumbs-navigation.htm
未经允许请勿转载:程序喵 » 【WordPress】实现面包屑导航