倒序显示主评论楼层号(支持评论分页)

最新代码移步到这里:只在WP主评论加上楼层号的方法『支持顺序、倒序』(2012.11.17)

我写了这篇《只在WP主评论加上楼层号的方法(支持评论分页)》后,很多朋友就问我“怎样实现倒序的主评论楼层号”,那时我折腾了一下,一直找不到只统计主评论(嵌套第一层)数量的函数(以前有总评论数的函数,但不适合),所以一直没实现。

昨晚(2010.8.2)37度高温让我很难入眠,想了一下,既然没有直接的函数,那么就只能直接用SQL过滤并统计出主评论数量,今天我在本地测试一翻,ok,搞定,唯一的缺点就是增加了数据库查询,没办法,谁叫WP自身没有此函数呢?

下面是方法,喜欢倒序显示评论的朋友可以折腾一下。

一、前提

1. 主题必须支持嵌套

2.设置WP嵌套评论排序为“由新到旧”

3. 主题有使用 mytheme_comment 回调函数(http://codex.wordpress.org/Template_Tags/wp_list_comments

二、改造回调函数

1. WP官方的默认 mytheme_comment 回调函数

function mytheme_comment($comment, $args, $depth){
$GLOBALS['comment'] = $comment;

?>
<li <?php comment_class(); ?> id="li-comment-<?php comment_ID() ?>">
	<div id="comment-<?php comment_ID(); ?>">
		<div class="comment-author vcard">
		<?php echo get_avatar($comment,$size='48',$default='<path_to_url>' ); ?>
		<?php printf(__('<cite class="fn">%s</cite> <span class="says">says:</span>'), get_comment_author_link()) ?>
	</div>
	<?php if ($comment->comment_approved == '0') : ?>
		<em><?php _e('Your comment is awaiting moderation.') ?></em>
		<br />
	<?php endif; ?>
	<div class="comment-meta commentmetadata"><a href="<?php echo htmlspecialchars( get_comment_link( $comment->comment_ID ) ) ?>"><?php printf(__('%1$s at %2$s'), get_comment_date(),  get_comment_time()) ?></a><?php edit_comment_link(__('(Edit)'),'  ','') ?></div>
		<?php comment_text() ?>
		<div class="reply">
			<?php comment_reply_link(array_merge( $args, array('depth' => $depth, 'max_depth' => $args['max_depth']))) ?>
		</div>
	</div>
<?php }

2. 修改后的回调函数,具体看注释

function mytheme_comment($comment, $args, $depth){
 $GLOBALS['comment'] = $comment;

 /* 主评论计数器 by zwwooooo */
     global $commentcount,$wpdb, $post;
     if(!$commentcount) { //初始化楼层计数器
          $comments = $wpdb->get_results("SELECT * FROM $wpdb->comments WHERE comment_post_ID = $post->ID AND comment_type = '' AND comment_approved = '1' AND !comment_parent");
          $cnt = count($comments);//获取主评论总数量
          $page = get_query_var('cpage');//获取当前评论列表页码
          $cpp=get_option('comments_per_page');//获取每页评论显示数量
         if (ceil($cnt / $cpp) == 1 || ($page > 1 && $page  == ceil($cnt / $cpp))) {
             $commentcount = $cnt + 1;//如果评论只有1页或者是最后一页,初始值为主评论总数
         } else {
             $commentcount = $cpp * $page + 1;
         }
     }
 /* 主评论计数器 end */

 ?>
 <li <?php comment_class(); ?> id="li-comment-<?php comment_ID() ?>">
     <div id="comment-<?php comment_ID(); ?>">
         <div class="comment-author vcard">
         <?php echo get_avatar($comment,$size='48',$default='<path_to_url>' ); ?>
         <?php printf(__('<cite class="fn">%s</cite> <span class="says">says:</span>'), get_comment_author_link()) ?>
     </div>
     <?php if ($comment->comment_approved == '0') : ?>
         <em><?php _e('Your comment is awaiting moderation.') ?></em>
         <br />
     <?php endif; ?>
     <div class="comment-meta commentmetadata"><a href="<?php echo htmlspecialchars( get_comment_link( $comment->comment_ID ) ) ?>"><?php printf(__('%1$s at %2$s'), get_comment_date(),  get_comment_time()) ?></a><?php edit_comment_link(__('(Edit)'),'  ','') ?></div>
         <?php comment_text() ?>
         <div class="reply">
             <?php comment_reply_link(array_merge( $args, array('depth' => $depth, 'max_depth' => $args['max_depth']))) ?>
         </div>
         <div class="floor"><!-- 主评论楼层号 by zwwooooo -->
             <?php if(!$parent_id = $comment->comment_parent) {printf('#%1$s', --$commentcount);} ?><!-- 当前页每个主评论自动-1 -->
         </div>
     </div>
 <?php }

3. 显示楼层号的 .floor 参考下面的 css

ol.commentlist li div.floor{position:absolute;top:0;right:0;}

搞定收工。

zww
or
oooo

“倒序显示主评论楼层号(支持评论分页)”有109条评论

  1. 7cbt says:

    这倒序的楼层也能加强用户的互动。也算一大亮点捏

    1. zwwooooo says:

      @7cbt 折腾就是为了这个

  2. empper says:

    每次来都有新收获,哈哈。

    1. zwwooooo says:

      @empper 一起折腾 :mrgreen:

  3. [...] 评论无限嵌套,非线性缩进+头像变小,楼层区分主评论和地下室,提示沙发、板凳、地板,逆序的留言板(来自zww)…一些小功能就不提了 [...]

  4. 為WordPress留言加入樓層顯示,支援階層式迴響(嵌套評論)、迴響分頁(評論分頁)且同時支援正序及倒序顯示評論(較舊及較新的迴響顯示在上方) | 到處閒晃 says:

    [...] 倒序顯示主評論樓層號(支持評論分頁) [...]

  5. imcx says:

    按文章步骤来,出现了这种错误:Call to a member function get_results() on a non-object
    放狗搜了好久也没解决,望指点~~

    1. zwwooooo says:

      @imcx
      sql语句错误?以前测试没问题的,检查一下,最近忙,没时间再测试,稍后看看吧。

  6. imcx says:

    《只在WP主评论加上楼层号的方法(支持评论分页)》根据这篇文章来的话,没有错误···

  7. 杜撰人生 » 关于 Paled 主题的那些事儿 says:

    [...] 倒序显示主评论楼层号(支持评论分页) [...]

  8. 自耕农 says:

    :mrgreen: 请教一下博主 怎么不统计嵌套评论的楼层呢

    1. zwwooooo says:

      @自耕农
      因为我觉得不需要,嵌套是随时有人回复的,况且嵌套总是比较少,所以别浪费查询数了

  9. [...] 4.准备逆序显示评论。参考zww的倒序显示主评论楼层号(支持评论分页)(顺序显示评论当然跳过这一步) [...]

  10. 无冷 says:

    这个我是在后台设置的,是不是3.1新带的功能就不知道了

    1. zwwooooo says:

      @无冷
      跟3.1没关系

  11. chzng says:

    我的评论顺序也是乱七八糟的,不安装时间顺序,就拿我的这篇文章 :http://www.lyove.com/ibox/gvan-y.html 来说,看每条评论的时间就能看得出,不是按照时间顺序来排列的,你的两种方法我都试过了,顺序都是乱的...什么原因呢?

    1. zwwooooo says:

      @chzng
      你可能用过那个嵌套插件,也就是说你一开始不是用WP原生的嵌套

  12. chzng says:

    我没有用过嵌套插件啊,我的主题的comment回调函数是在functions.php里面,和你所说的官网WP回调函数完全一样,我是按照你的步骤来添加的。现在用的是你写的倒序显示楼层的代码,评论顺序按时间排列了,但楼层还是倒序的。哪里又出问题了?

    1. zwwooooo says:

      @chzng
      我很好奇你有没有在“WP后台->设置->讨论”那里设置评论倒序?

  13. chzng says:

    这是我的主题的下载地址:http://www.lyove.com/wp-content/files/Gvan-Y.zip ,如果可能的话,你下载后能帮我查看下代码哪里出错了吗?谢谢了! :smile:

  14. [...] 解决方法:根据zww的《倒序显示主评论楼层号(支持评论分页)》这篇文章做了修 [...]

  15. 倒序显示主评论楼层号 - 乱了感觉 says:

    [...] 一直在用zwwoooo大湿的评论楼层号代码,之前不是倒序显示的,而后台设置的评论是由新到旧显示,这样就会造成新评论总是一楼,我了个去。于是想改成倒序显示评论楼层号的,遂跑道zwwoooo那里看看,发现了他写的《倒序显示主评论楼层号(支持评论分页)》。试着按照他写的代码折腾了一下,确实,一般文章的主评论楼层号是倒序显示了。但是问题是我的留言本的评论分页数不是按照后台设置的,结果每页的楼层数都相同,我那个晕。于是弃用他写的方法,自己折腾去。最终效果如下: [...]

  16. 我设置每页显示15条评论,然后第一页第一条显示为17楼而不是1楼,第二页第一条显示为32楼……… :?:

    1. zwwooooo says:

      @星野苍真
      评论调用函数要注意参数有木有排除pingback这类。

    2. @zwwooooo
      pingback一般都不超过5条,而且没有pingback的文章第一条评论也是显示为17楼…………

    3. zwwooooo says:

      @星野苍真
      评论要把pingback的也要输出,不然就不准了

回复给 自耕农 ¬
取消回复

昵称 *

网址

B em del U Link Code Quote