wordpress主题开发时,需要在当前页面添加个面包屑导航的功能,当然有wordpress插件能实现此功能。对于面包屑导航的由来就不赘述了,但它的功能还是不错的。不仅能让蜘蛛更好的顺着链接走下去,也能让我们的访客通过面包屑导航来清晰的访问其他文章目录。

面包屑实现功能

对于wordpress主题的功能,我们肯定是要放到当前wordpress主题的functions.php文件中了。


// 面包屑导航 
function get_breadcrumbs()
{
global $wp_query;
if ( !is_home() ){
// Start the UL
echo '<ul id="crumbs">';
// Add the Home link
echo '<li><i class="fa fa-home"></i><a href="'. get_settings('home') .'">'. get_bloginfo('name') .'</a></li>';
if ( is_category() )
{
$catTitle = single_cat_title( "", false );
$cat = get_cat_ID( $catTitle );
echo "<li> » ". get_category_parents( $cat, TRUE, " » " ) ."</li>";
}
elseif ( is_archive() && !is_category() )
{
echo "<li> » Archives</li>";
}
elseif ( is_search() ) {
echo "<li> » Search Results</li>";
}
elseif ( is_404() )
{
echo "<li> » 404 Not Found</li>";
}
elseif ( is_single() )
{
$category = get_the_category();
$category_id = get_cat_ID( $category[0]->cat_name );
echo '<li> » '. get_category_parents( $category_id, TRUE, " » " );
echo the_title('','', FALSE) ."</li>";
}
elseif ( is_page() )
{
$post = $wp_query->get_queried_object();
if ( $post->post_parent == 0 ){
echo "<li> » ".the_title('','', FALSE)."</li>";
} else {
$title = the_title('','', FALSE);
$ancestors = array_reverse( get_post_ancestors( $post->ID ) );
array_push($ancestors, $post->ID);
foreach ( $ancestors as $ancestor ){
if( $ancestor != end($ancestors) ){
echo '<li> » <a href="'. get_permalink($ancestor) .'">'. strip_tags( apply_filters( 'single_post_title', get_the_title( $ancestor ) ) ) .'</a></li>';
} else {
echo '<li> » '. strip_tags( apply_filters( 'single_post_title', get_the_title( $ancestor ) ) ) .'</li>';
}
}
}
}
// End the UL
echo "</ul>";
}
}

面包屑代码调用

在需要引用的位置放以下代码,以本站的面包屑导航为例,具体div可自行修改。


<div class="crumbs_box">
<?php get_breadcrumbs(); ?>
</div>

面包屑css样式

本站给出基本的css样式,请各位根据自己的wordpress主题样式来自行修改。


.crumbs_box{padding:15px 0 30px;color:#9c9c9c;font-size:14px}
.crumbs_box a{color:#9c9c9c;margin: 0 2px;}
.crumbs_box a:hover{color:#45B6F7;}