做 WordPress 主題不僅僅是前端的事,工程師們還必須瞭解關於 WordPress 主題各方面細節的優化,之前小編講到 WordPress 自動添加 alt 和 title 信息的文章,而今天緊接着給大家分享下 WordPress 麪包屑導航功能的使用以及帶來的好處 。
麪包屑對於一個網站來説,相當於是頁面結構的一個導航,是網頁導航設計中一個標準設計模式,而今天我們講的是如何通過代碼來實現 WordPress 麪包屑導航的功能,本站的老訪客都知道,小編在用 WordPress 主題的時候十分的不喜歡用插件,儘管很方便,但會降低網站的打開速度!

教程開始了:
- function get_breadcrumbs()
- global $wp_query;
- if ( !is_home() ){
- echo '<ul class="breadcrumbs">';
- echo '<li><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>';
- }
- }
- echo "</ul>";
- }
-
- <?php if (function_exists('get_breadcrumbs')){get_breadcrumbs(); } ?>
將上面的調用函數放進 WordPress 主題文件下的 archive.php 、 single.php 、 index.php 、 search.php 等頁面的相應位置,當然這是你想放哪就放哪,只要你覺得美觀就好,我們都習慣放文章上方,header 的下方。。。
- ul.breadcrumbs {
- padding: 0;
- font-size:12px;
- ul.breadcrumbs li {
- margin: 0 5px 0 0;
- }
再將這段 css 放進主題文件下的 css 裏即可。。。
這樣 WordPress 麪包屑導航的功能基本就大功告成了,刷新下頁面試試哈,樣式效果都還不錯吧!