用get_comments()函数实现带头像最新评论

其实WordPress官方一直不推荐直接用SQL语言调用数据库数据,所以一直以来WordPress官方主题审核中,直接用SQL语句的代码是通不过审核的,这也是为啥我提交的主题都没有提供“带头像的最新评论”代码。

去年提交的主题偶尔会让你通过使用SQL语句实现的带头像最新评论的代码,后来就不行了,审核结果是不准直接使用SQL,请使用get_comments()。但因为对get_comments()函数不熟,加上官方函数文档不够详细,所以一直没折腾。

今年国庆窝在家里,比较闲,就稍微研究了一下,没想到竟然搞定了,虽然效率方面没有直接用SQL快,但这点速度差异我们是感觉不出来的,速度的问题还是交给主机吧。

下面是我折腾好的代码,直接CP到侧边栏即可使用,当然还要根据自己主题设置一下css样式。

get_comments()函数实现的带头像最新评论代码

2010.10.10Edit:增加对表情输出)

<h3>Recent Comments</h3>
<ul class="recentcomments">
<?php
$show_comments = 10; //评论数量
$my_email = get_bloginfo ('admin_email'); //获取博主自己的email
$i = 1;
$comments = get_comments('number=200&status=approve&type=comment'); //取得前200个评论,如果你每天的回复量超过200可以适量加大
foreach ($comments as $rc_comment) {
	if ($rc_comment->comment_author_email != $my_email) {
		?>
		<li><?php echo get_avatar($rc_comment->comment_author_email,32); ?><span class="comment_author"><?php echo $rc_comment->comment_author; ?> says:</span><br /><a href="<?php echo get_permalink($rc_comment->comment_post_ID); ?>#comment-<?php echo $rc_comment->comment_ID; ?>"><?php echo convert_smilies($rc_comment->comment_content); ?></a></li>
		<?php
		if ($i == $show_comments) break; //评论数量达到退出遍历
		$i++;
	} // End if
} //End foreach
?>
</ul>

其中 $show_comments = 10 里面的 10 是要显示的评论数量。

ps1:评论截断你可以用php截断函数 mb_strimwidth() 实现,具体参考《mb_strimwidth函数的简单应用

ps2:也可以用css的overflow:hidden属性实现假截断,参考我的css:

#sidebar .recentcomments img.avatar{width:26px;height:26px;float:left;position:relative;border:1px solid #ddd;margin:0 5px 0 0;padding:2px;}
#sidebar ul.recentcomments{list-style:none;padding-left:0;}
#sidebar ul.recentcomments li{margin:5px 0 0;line-height:16px;height:32px;overflow:hidden;}
#sidebar .comment_author{color:#999;}

效果图:

折腾完,喜欢用哪个就用哪个吧。

zww
or
oooo

发表评论

昵称 *

网址

B em del U Link Code Quote