wordpress获取分类下文章列表四种方法

一、使用query_posts()函数

以下代码实际上使用query_posts()函数调取分类目录下的文章,showposts是调取的数量。

  1. <?php
  2.     $cats = get_categories();
  3.     foreach ( $cats as $cat ) {
  4.     query_posts( 'showposts=10&cat=' . $cat->cat_ID );
  5. ?>
  6.     <h3><?php echo $cat->cat_name; ?></h3>
  7.     <ul class="sitemap-list">
  8.         <?php while ( have_posts() ) { the_post(); ?>
  9.         <li><a href="<?php the_permalink(); ?>"><?php the_title(); ?></a></li>
  10.         <?php } wp_reset_query(); ?>
  11.     </ul>
  12. <?php } ?>

在官方文档中,这样强调:“如果我们不得不用到query_posts(),必须确保每次使用query_posts()后同时执行wp_reset_query();”。这就是为什么在上面的代码中加上了wp_reset_query()的原因。
修改其中的数字10可以设定显示的篇数,可用于在单页面上显示全部分类文章。

二、使用get_posts()函数

只需通过get_posts来获取分类ID就可以输出分类下的文章,以及通过numberposts来控制文章显示的数量。

  1. <?php $posts = get_posts( "category=4&numberposts=10" ); ?>  
  2. <?php if( $posts ) : ?>  
  3. <ul><?php foreach( $posts as $post ) : setup_postdata( $post ); ?>  
  4. <li>  
  5. <a href=”<?php the_permalink() ?>” rel=”bookmark” title=”<?php the_title(); ?>><?php the_title(); ?></a>  
  6. </li>  
  7. <?php endforeach; ?>  
  8. </ul>  
  9. <?php endif; ?>

三、结合wp_list_categories()函数输出分类标题

  1. <h2> <?php wp_list_categories('include=11&title_li=&style=none'); ?> </h2>
  2.       <!--//输出 ID 为11的分类的标题 -->
  3.          <?php  echo category_description(11); ?>
  4.       <!--//输出 ID 为11的分类的描述 -->
  5.           <?php query_posts('showposts=10&cat=11'); ?>
  6.       <!-- //query_posts 给 The Loop 限定的条件是:显示12篇日志和分类 ID 为11 -->
  7.            <?php while (have_posts()) : the_post(); ?>
  8.       <!--//The Loop 开始 -->
  9.      <li>
  10.       <a href="<?php the_permalink() ?>" rel="bookmark" title="<?php the_title(); ?>"><? echo wp_trim_words( get_the_title(),24 ); ?></a>
  11.        <?php  the_time('m/d'); ?>
  12.      </li>
  13.       <!-- //用列表的方式输出带有链接的文章标题-->
  14.             <?php endwhile;wp_reset_query(); ?>
  15.       <!--//The Loop 结束 -->

四、自定义函数

1、我们自定义一个函数popularPosts()

  1. function popularPosts($num) {  
  2.     global $wpdb;  
  3.       
  4.     $posts = $wpdb->get_results("SELECT comment_count, ID, post_title FROM $wpdb->posts ORDER BY comment_count DESC LIMIT 0 , $num");  
  5.       
  6.     foreach ($posts as $post) {  
  7.         setup_postdata($post);  
  8.         $id = $post->ID;  
  9.         $title = $post->post_title;  
  10.         $count = $post->comment_count;  
  11.           
  12.         if ($count != 0) {  
  13.             $popular .= '<li>';  
  14.             $popular .= '<a href="' . get_permalink($id) . '" title="' . $title . '">' . $title . '</a> ';  
  15.             $popular .= '</li>';  
  16.         }  
  17.     }  
  18.     return $popular;  
  19. }

这里使用get_results()查询了数据库,相对速度快一点。
2、调用函数 popularPosts(10) 显示10篇文章。

  1. div class="popular">  
  2.     <h2>Most Popular Posts</h2>  
  3.     <ul>  
  4.         <?php echo popularPosts(10); ?>  
  5.     </ul>  
  6. </div>

发布日期:

所属分类: Wordpress 综合 标签: