详解WordPress中怎么建立文章存档页面

 4650

什么是文章存档页面?WordPress中怎么轻松建立文章存档页面?下面本篇文章给大家介绍一下WordPress中建立存档页面的3种方法,希望对大家有所帮助!


详解WordPress中怎么建立文章存档页面


可能你会问,什么是文章存档页面,有什么用?开始之前,我们先来感性认识一下什么是存档页面,请点击查看本站的 Sitemap。你可以看到这个存档页面列出我博客上所有文章和所有的页面,一个方面如果读者想一下子看到本站的文章,那么到此页面来看就轻松多了;另外据说对SEO有帮助,目前我还没有证实。最后,你可能已经意识到,原来网站根目录下不是有个sitemap.xml了吗?为什么还要创建这样的存档页面呢?其实sitemap.xml是给搜索引擎蜘蛛看,而这个存档页面是弄给人看的。下面我来讲讲如何创建这页面,感兴趣的可以看看。

方法一:SQL读取数据库

方法一展示的存档页面效果就是本站的Sitemap效果,其实就是创建一个自定义的页面模板,操作起来也很简单,不需要你懂太多的编程技术,唯一要配置的就是修改sitemap.xml的链接。方法一的优点是,我使用的是SQL直接从数据库中读取数据,而且只进行两次数据库连接,避免了使用WordPress内置函数,速度相对来说会快那么一点点;缺点是,你要复制的代码相对来说长点。下面看看具体步骤:

1、在当前主题目录下新建一个php文件,命名为sitemap.php,然后将page.php中的所有代码复制到sitemap.php中

2、删除sitemap.php开头的所有注释,即 /* 与 */ ,以及它们之间的所有内容

3、将第一个 <?php 改成

  1. <?php
  2. /*
  3.  * Template Name: sitemap
  4.  * @author: zzTuKu.com  
  5.  * @Blog  : https://www.zztuku.com/
  6.  */

4、将 <?php the_content(); ?> 改成:

  1. <div class="myArchive">
  2. <ul>
  3. <?php
  4. /**
  5.  * WordPress分类存档页面
  6.  * 作者:站长图库
  7.  * 博客:https://www.zztuku.com/
  8.  * 最后修改:2012年8月27日
  9.  */
  10.     $categoryPosts = $wpdb->get_results("
  11.     SELECT post_title, ID, post_name, slug, {$wpdb->prefix}terms.term_id AS catID, {$wpdb->prefix}terms.name AS categoryname
  12.     FROM {$wpdb->prefix}posts, {$wpdb->prefix}term_relationships, {$wpdb->prefix}term_taxonomy, {$wpdb->prefix}terms
  13.     WHERE {$wpdb->prefix}posts.ID = {$wpdb->prefix}term_relationships.object_id
  14.     AND {$wpdb->prefix}terms.term_id = {$wpdb->prefix}term_taxonomy.term_id
  15.     AND {$wpdb->prefix}term_taxonomy.term_taxonomy_id = {$wpdb->prefix}term_relationships.term_taxonomy_id
  16.     AND {$wpdb->prefix}term_taxonomy.taxonomy = 'category'
  17.     AND {$wpdb->prefix}posts.post_status = 'publish'
  18.     AND {$wpdb->prefix}posts.post_type = 'post'
  19.     ORDER BY {$wpdb->prefix}terms.term_id, {$wpdb->prefix}posts.post_date DESC");
  20.  
  21.     $postID = 0;
  22.     if ( $categoryPosts ) :
  23.         $category = $categoryPosts[0]->catID;
  24.         foreach ($categoryPosts as $key => $mypost) :
  25.             if($postID == 0) {
  26.                 echo '<li><strong>分类:</strong> <a title="'.$mypost->categoryname.'" href="'.get_category_link($mypost->catID).'">'.$mypost->categoryname."</a>\n";
  27.                 echo '<ul>';
  28.             }
  29.             
  30.             if($category == $mypost->catID) {          
  31. ?>
  32.     <li><a title="<?php echo $mypost->post_title; ?>" href="<?php echo get_permalink( $mypost->ID ); ?>"><?php echo $mypost->post_title; ?></a></li>
  33. <?php
  34.                 $category = $mypost->catID;
  35.                 $postID++;
  36.             }
  37.             else {
  38.                 echo "</ul>\n</li>";
  39.                 echo '<li><strong>分类:</strong> <a title="'.$mypost->categoryname.'" href="'.get_category_link($mypost->catID).'">'.$mypost->categoryname."</a>\n";
  40.                 echo '<ul>';
  41. ?>
  42.     <li><a title="<?php echo $mypost->post_title; ?>" href="<?php echo get_permalink( $mypost->ID ); ?>"><?php echo $mypost->post_title; ?></a></li>
  43. <?php
  44.                 $category = $mypost->catID;
  45.                 $postID = 1;
  46.             }
  47.         endforeach;
  48.     endif;
  49.     echo "</ul>\n</li>";
  50. ?>
  51.  
  52. <li><strong>页面</strong>
  53. <ul>
  54. <?php
  55.     // 读取所有页面
  56.     $mypages = $wpdb->get_results("
  57.         SELECT post_title, post_name, ID
  58.         FROM {$wpdb->prefix}posts
  59.         WHERE post_status = 'publish'
  60.         AND post_type = 'page'");
  61.  
  62.     if ( $mypages ) :
  63.         foreach ($mypages as $mypage) :
  64. ?>
  65.     <li><a title="<?php echo $mypage->post_title; ?>" href="<?php echo get_permalink( $mypage->ID ); ?>"><?php echo $mypage->post_title; ?></a></li>
  66.     <?php endforeach; echo "</ul>\n</li>"; endif; ?>
  67. </ul>
  68. <p><a href="https://www.zztuku.com/sitemap.xml">查看 sitemap.xml</a></p>
  69. </div>

最后将最后第二行的 https://www.zztuku.com/sitemap.xml 改成你自己的 sitemap.xml 链接就可以了,修改完之后记得用UTF-8编码保存,否则中文可能会乱码。

上面的代码直接用到你的WordPress站点中理论上讲是没多大问题,但是可能在美观程度上会有一定的问题,你可以根据个人能力用CSS稍微修饰一下就可以了,另外我这里提供了一个CSS的范例,你可以参考,复制到主题目录下的style.css中,可能会达到本站sitemap的样式效果:

  1. .myArchive {
  2.     line-height:18px;
  3.     margin:1.5em 0;
  4.     color:#555555;
  5.     font-size:14px;
  6. }
  7. .myArchive h2 {
  8.     font-size:16px;
  9.     margin:0 0 10px;
  10.     font-weight:bold;
  11. }
  12. .myArchive ul {
  13.     line-height:21px;
  14.     padding:0 0 0 2em;
  15. }
  16. .myArchive ul li {
  17.     background:none;
  18.     list-style-type:disc;
  19.     margin:0;
  20.     padding-left:10px;
  21. }
  22. .myArchive a {
  23.     color:#2970A6;
  24.     outline:medium none;
  25.     text-decoration:none;
  26. }
  27. .myArchive a:hover {
  28.     text-decoration:underline;
  29. }
  30. .myArchive ul li ul {
  31.     margin:10px 0;
  32. }
  33. .myArchive ul li ul li {
  34.     list-style-type:circle;
  35. }

5、进入WordPress管理后台 - 页面 - 创建页面,标题为文章存档(可以自己起名),内容不要填,右侧可以选择模板,选择 sitemap 即可

6、文章存档页就创建成功了。


方法二:使用wp_get_archives函数

方法二的操作也很简单,代码量更少,不过这里只是纯粹地列出所有的文章,并不会像方法一那样按分类来列出文章,略显单调,不过如果嫌方法一麻烦的话可以试试。下面是具体操作方法:

1~3步跟方法一是一样的,第4步:

将 the_content(); 改成以下代码就可以了:

  1. echo '<ul>';
  2. wp_get_archives('type=postbypost&show_post_count=1');
  3. echo '</ul>';

5~6步也跟方法一一样。


方法三:使用插件

关于WordPress存档页面的插件由很多,感兴趣的话,请自行搜索,这里就不仔细介绍。


本文网址:https://www.zztuku.com/index.php/detail-13998.html
站长图库 - 详解WordPress中怎么建立文章存档页面
申明:本文转载于《露兜即刻》,如有侵犯,请 联系我们 删除。

评论(0)条

您还没有登录,请 登录 后发表评论!

提示:请勿发布广告垃圾评论,否则封号处理!!

    编辑推荐