当前位置: 首页 > 技术随笔 > WordPress实现面包屑导航

WordPress实现面包屑导航

最近考虑为本网站添加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('>>');
?>

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

5 0
我们认为: 用户的主要目的,是为了获取有用的信息,而不是来点击广告的。因此本站将竭力做好内容,并将广告和内容进行分离,确保所有广告不会影响到用户的正常阅读体验。用户仅凭个人意愿和兴趣爱好点击广告。
我们坚信:只有给用户带来价值,用户才会给我们以回报。
CodePlayer技术交流群1CodePlayer技术交流群1

帮朋友打一个硬广告:

P2P网贷系统(Java版本) 新年低价大促销,多年P2P技术积累,系统功能完善(可按需定制,可支持第三方存管、银行存管),架构稳定灵活、性能优异、二次开发快速简单。 另可提供二次开发、安装部署、售后维护、安全培训等一条龙服务。

外行看热闹,内行看门道。可以自信地认为,在系统设计上,比市面上的晓风、迪蒙、方维、绿麻雀、国融信、金和盛等P2P系统要好。
深圳地区支持自带技术人员现场考察源代码、了解主要技术架构,货比三家,再决定是否购买。

也可推荐他人购买,一旦完全成交,推荐人可获得实际售价 10% 的返现。
有意向者,详情请 点击这里 联系,工作时间立即回复。