licream's blog


11月 30th, 2009

抛弃WordPress Related Posts,也能实现它

wordpress, by Licream.

今天在网上发现有个很实用的功能,完全可替代WordPress Related Posts插件,现分享给大家,我直接上方法了!

下面的方法的出自http://www.hacklog.cn/wordpress/wpskills/wordpress-related-posts-with-no-plugin.html功能更强大了
将下面的代码添加到你目前使用的主题的functions.php文件的最后一个?>标签前面即可


#######  START   ##########     显示相关日志    #################    START   #########
###########################   www.hacklog.cn    ######################################
    $wp_rp=array(
    'limit'=>6, //显示几条相关文章
    'wp_rp_rss'=>true, //在rss feed 中显示相关文章
    'wp_no_rp'=>'random', //无相关文章时的选择:text 或random(random为显示随机文章)
    'wp_rp_date'=>true, //显示日志发布日期
    'wp_rp_comments'=>true, //显示日志评论数
    'wp_rp_title_tag'=>'h3',//相关日志标题标签(h2 ,h3 ,h4 ,p ,div)
    );
function wp_get_random_posts ($limitclause="") {
    global $wpdb, $tableposts, $post;

    $q = "SELECT ID, post_title, post_content,post_excerpt, post_date, comment_count FROM $tableposts WHERE post_status = 'publish' AND post_type = 'post' AND ID != $post->ID ORDER BY RAND() $limitclause";
    return $wpdb->get_results($q);
}

    function wp_get_related_posts()
    {
    global $wpdb, $post,$table_prefix,$wp_rp;
    $limit =$wp_rp["limit"];
    if(!$post->ID){return;}
    $now = current_time('mysql', 1);
    $tags = wp_get_post_tags($post->ID);

    $taglist = "'" . $tags[0]->term_id. "'";

    $tagcount = count($tags);
    if ($tagcount > 1) {
        for ($i = 1; $i < $tagcount; $i++) {
            $taglist = $taglist . ", '" . $tags[$i]->term_id . "'";
        }
    }

    if ($limit) {
        $limitclause = "LIMIT $limit";
    }   else {
        $limitclause = "LIMIT 10";
    }

    $q = "SELECT p.ID, p.post_title, p.post_content,p.post_excerpt, p.post_date,  p.comment_count, count(t_r.object_id) as cnt FROM $wpdb->term_taxonomy t_t, $wpdb->term_relationships t_r, $wpdb->posts p WHERE t_t.taxonomy ='post_tag' AND t_t.term_taxonomy_id = t_r.term_taxonomy_id AND t_r.object_id  = p.ID AND (t_t.term_id IN ($taglist)) AND p.ID != $post->ID AND p.post_status = 'publish' AND p.post_date_gmt < '$now' GROUP BY t_r.object_id ORDER BY cnt DESC, p.post_date_gmt DESC $limitclause;";

    $related_posts = $wpdb->get_results($q);

    $output = "";
    //不存在相关日志则显示随机日志
    if (!$related_posts)
    {
        if($wp_rp['wp_no_rp'] == "text")
        {
            $output  .= '<li>无相关日志</li>';
        }
        else

        {
            if($wp_rp['wp_no_rp'] == "random")
            {
            $wp_no_rp_text= '随机日志';
            $related_posts = wp_get_random_posts($limitclause);
            }  

            $wp_rp_title = $wp_no_rp_text;
        }
    }

    foreach ($related_posts as $related_post )
    {
        $output .= '<li>';
        if($wp_rp['wp_rp_date'])
        {
        $dateformat = get_option('date_format');
        $output .= mysql2date($dateformat, $related_post->post_date) . "  //  ";
        }
        $output .=  '<a href="'.get_permalink($related_post->ID).'" title="'.wptexturize($related_post->post_title).'">'.wptexturize($related_post->post_title).'</a>';
        if ($wp_rp["wp_rp_comments"])
        {
        $output .=  " (" . $related_post->comment_count . ")";
        }
    $output .=  '</li>';
    }
    $output = '<ul class="related_post">' . $output . '</ul>';
    $wp_rp_title_tag = $wp_rp["wp_rp_title_tag"];

        if(!$wp_rp_title_tag)
        $wp_rp_title_tag ='h3';
        if($wp_rp_title != '')
        $output =  '<'.$wp_rp_title_tag.'  class="related_post_title">'.$wp_rp_title .'</'.$wp_rp_title_tag.'>'. $output;
    return $output;
}

    function wp_related_posts_attach($content)
    {
       global $wp_rp;
          if (is_single()||(is_feed() && $wp_rp["wp_rp_rss"]))
          {
          $output = wp_get_related_posts();
          $content = $content . $output;
           }

    return $content;
    }

add_filter('the_content', 'wp_related_posts_attach',100);
#######    END     ##########     显示相关日志    #################    END   #########
###########################   www.hacklog.cn    ######################################

--转自Hacklog【荒野无灯weblog】

Back Top

回复自“抛弃WordPress Related Posts,也能实现它”

评论 (16) 发表评论
  1. @keykey: 。好像可以设置显示数量的,

  2. 大概看看,貌似是根据tag来查mysql的,估计Related Posts算法会比这个复杂很多,按这样的过滤恐怕我就没多少文章相关联了

  3. 呵呵~~唯有羡慕了~~~菜鸟飞过~~~

  4. @荒野无灯: 期待你的完美版,优化下哈

  5. 看了你这篇文章,我也有了想法 ,呵呵,马上写了一篇不用插件实现相关日志显示的博文:-)

  6. @荒野无灯: 主题问题,在firefox,Chrome浏览器会看不清。IE正常。

  7. 这个代码高亮里面的代码看不清哦

  8. @風の傷: 我也是PHP菜鸟,常来看看:)

  9. 厉害!学习了~ 改天试用一下, 我是PHP菜鸟 呵呵

  10. @漠岚: 是指有人留言了会有邮件通知?之前有过。忘了是不是用了插件的

  11. @Licream: 建议找一个留言发送邮件的插件 ,,

  12. @Joyo: 你是指这个页面?这是主题带的效果。我以为你是说首页那个评论

  13. 用的是:WP-RecentComments插件,呵呵

  14. 一直觉得你的评论很漂亮,请教下是如何实现的~

  15. @漠岚: 是直接嵌入的,没有插件
    PHP不会,哎。

  16. 没学过php那 ,你这个是直接嵌入到wp里面了?没做插件

发表评论

您的电子邮箱不会被公开。 标记为 * 的区域必须填写

*