WordPress 主题不仅仅是前端的事,工程师们还必须了解关于 WordPress 主题各方面细节的优化,之前小编讲到 WordPress 自动添加 alt 和 title 信息的文章,而今天紧接着给大家分享下 WordPress 面包屑导航功能的使用以及带来的好处 。

面包屑对于一个网站来说,相当于是页面结构的一个导航,是网页导航设计中一个标准设计模式,而今天我们讲的是如何通过代码来实现 WordPress 面包屑导航的功能,本站的老访客都知道,小编在用 WordPress 主题的时候十分的不喜欢用插件,尽管很方便,但会降低网站的打开速度!

教程开始了:

  1. function get_breadcrumbs()  
  2.     global $wp_query;  
  3.     if ( !is_home() ){  
  4.           
  5. echo '<ul class="breadcrumbs">';  
  6.           
  7. echo '<li><a href="'. get_settings('home') .'">'. get_bloginfo('name') .'</a></li>';  
  8.     
  9. if ( is_category() )  
  10.         {  
  11. $catTitle = single_cat_title( "", false );  
  12.             $cat = get_cat_ID( $catTitle );  
  13. echo "<li> &raquo; ". get_category_parents( $cat, TRUE, " &raquo; " ) ."</li>";  
  14.         }  
  15. elseif ( is_archive() && !is_category() )  
  16.         {  
  17. echo "<li> &raquo; Archives</li>";  
  18.         }  
  19. elseif ( is_search() ) {  
  20.     
  21. echo "<li> &raquo; Search Results</li>";  
  22.         }  
  23. elseif ( is_404() )  
  24.         {  
  25. echo "<li> &raquo; 404 Not Found</li>";  
  26.         }  
  27. elseif ( is_single() )  
  28.         {  
  29. $category = get_the_category();  
  30.             $category_id = get_cat_ID( $category[0]->cat_name );  
  31.             echo '<li> &raquo; '. get_category_parents( $category_id, TRUE, " &raquo; " );  
  32. echo the_title('','', FALSE) ."</li>";  
  33.         }  
  34. elseif ( is_page() )  
  35.         {  
  36. $post = $wp_query->get_queried_object();  
  37.     
  38. if ( $post->post_parent == 0 ){  
  39.     
  40. echo "<li> &raquo; ".the_title('','', FALSE)."</li>";  
  41.     
  42. else {  
  43.                 $title = the_title('','', FALSE);  
  44. $ancestors = array_reverse( get_post_ancestors( $post->ID ) );  
  45.                 array_push($ancestors$post->ID);  
  46.                 foreach ( $ancestors as $ancestor ){  
  47. if$ancestor != end($ancestors) ){  
  48.                         echo '<li> &raquo; <a href="'. get_permalink($ancestor) .'">'. strip_tags( apply_filters( 'single_post_title', get_the_title( $ancestor ) ) ) .'</a></li>';  
  49. else {  
  50.                         echo '<li> &raquo; '. strip_tags( apply_filters( 'single_post_title', get_the_title( $ancestor ) ) ) .'</li>';  
  51.                 }  
  52.         }  
  53.           
  54. echo "</ul>";  
  55.     }  
    1. <?php if (function_exists('get_breadcrumbs')){get_breadcrumbs(); } ?>  

将上面的调用函数放进 WordPress 主题文件下的 archive.php 、 single.php 、 index.php 、 search.php 等页面的相应位置,当然这是你想放哪就放哪,只要你觉得美观就好,我们都习惯放文章上方,header 的下方。。。

  1. ul.breadcrumbs {  
  2.     padding: 0;  
  3.     font-size:12px;  
  4. ul.breadcrumbs li {  
  5.     margin: 0 5px 0 0;  
  6. }  

再将这段 css 放进主题文件下的 css 里即可。。。
这样 WordPress 面包屑导航的功能基本就大功告成了,刷新下页面试试哈,样式效果都还不错吧!