WordPress根据分类实现文章相关推荐

在一些站点中,我们经常可以看到一篇文章结束底部有相关文章推荐,那么WordPress如何实现推荐相关文章这个功能呢?其实,WordPress下有很多插件就可以实现这种功能,方便快捷。不过,插件配置虽简单,但对网站性能不好。所以想用插件实现这种功能的朋友可以自行搜索相关插件。下面主要介绍代码的方法实现文章相关推荐。

方法1: 通过获取该文章下的分类id,然后获取该分类下的文章,来实现相关文章推荐的目的。

<ul id="cat_related">
<?php
global $post;
$cats = wp_get_post_categories($post->ID);
if ($cats) {
    $args = array(
          'category__in' => array( $cats[0] ),
          'post__not_in' => array( $post->ID ),
          'showposts' => 6,
          'caller_get_posts' => 1
      );
 
  query_posts($args);
  if (have_posts()) {
    while (have_posts()) {
      the_post(); update_post_caches($posts); ?>
  <li>* <a href="<?php the_permalink(); ?>" rel="bookmark" title="<?php the_title_attribute(); ?>"><?php the_title(); ?></a></li>
<?php
    }
  } 
  else {
    echo '<li>* 暂无相关文章</li>';
  }
  wp_reset_query(); 
}
else {
  echo '<li>* 暂无相关文章</li>';
}
?>
</ul>

方法2: 思路和上面一样,不过在获取文章的时候用sql语句来直接读取6篇文章,而不是用wp的函数query_posts().

<ul id="cat_related">
<?php
global $post, $wpdb;
$cats = wp_get_post_categories($post->ID);
if ($cats) {
  $related = $wpdb->get_results("
  SELECT post_title, ID
   
  FROM {$wpdb->prefix}posts,{$wpdb->prefix}term_relationships, {$wpdb->prefix}term_taxonomy
  
  WHERE {$wpdb->prefix}posts.ID = {$wpdb->prefix}term_relationships.object_id
 
  AND {$wpdb->prefix}term_taxonomy.taxonomy = 'category'
 
  AND {$wpdb->prefix}term_taxonomy.term_taxonomy_id = {$wpdb->prefix}term_relationships.term_taxonomy_id
 
  AND {$wpdb->prefix}posts.post_status = 'publish'
 
  AND {$wpdb->prefix}posts.post_type = 'post'
  
   AND {$wpdb->prefix}term_taxonomy.term_id = '" . $cats[0] . "'
 
  AND {$wpdb->prefix}posts.ID != '" . $post->ID . "'
 
  ORDER BY RAND( )  LIMIT 6");
 
  if ( $related ) {
      foreach ($related as $related_post) {
?>
    <li>* <a href="<?php echo get_permalink($related_post->ID); ?>" rel="bookmark" title="<?php echo $related_post->post_title; ?>"><?php echo $related_post->post_title; ?></a></li>
 
<?php
    } 
  }
  else {
    echo '<li>* 暂无相关文章</li>';
  } 
}
else {
  echo '<li>* 暂无相关文章</li>';
}
?>
</ul>

 

作者: admin

发表评论