李锋镝的博客

  • 首页
  • 时间轴
  • 评论区显眼包🔥
  • 左邻右舍
  • 博友圈
  • 关于我
    • 关于我
    • 另一个网站
    • 我的导航站
    • 网站地图
    • 赞助
  • 留言
  • 🚇开往
Destiny
自是人生长恨水长东
  1. 首页
  2. 原创
  3. WP插件
  4. 正文

WordPress实现用户评论等级排行榜插件

2025年12月9日 411点热度 0人点赞 6条评论

前几天逛博客,看到大家的博客都有很多好玩的页面,比如Hary大佬的博客中有一个互动排行榜页面。

还有皮总的博客皮皮社上面的评论用户等级。

感觉大家的网站都很有趣,于是也打算自己实现一个评论等级排行榜,所以就写了一个WordPress插件。

插件主要功能如下:

  • 统计用户评论数
  • 通过简码的方式展示评论用户排行榜

简码实现的代码很简单:

function cur_render_rank_top($atts) {

    $atts = shortcode_atts(array(
        'num'         => 10,
        'avatar_size' => 64,
        'columns'     => 3,
        'title'       => '评论等级排行榜',
    ), $atts, 'comment_rank_top');

    $limit = min(intval($atts['num']), 50);
    $avatar_size = intval($atts['avatar_size']);
    $avatar_size = $avatar_size < 32 ? 32 : $avatar_size;
    $columns = intval($atts['columns']);
    $columns = $columns < 1 ? 1 : ($columns > 4 ? 4 : $columns);
    $custom_title = esc_html($atts['title']);

    global $wpdb;
    $table_prefix = $wpdb->prefix;

    $top_users = $wpdb->get_results($wpdb->prepare(
        "SELECT
            COUNT(*) as comment_count,
            comment_author_email,
            comment_author,
            comment_author_url
         FROM {$table_prefix}comments
         WHERE comment_approved = '1' AND user_id != 1
           AND comment_type NOT IN ('pingback', 'trackback')
         GROUP BY comment_author
         ORDER BY comment_count DESC
         LIMIT %d",
        $limit
    ), ARRAY_A);

    if (empty($top_users)) {
        return sprintf(
            '<div class="comment-rank-top">
                <h3 class="rank-top-title">%s</h3>
                <p class="rank-top-empty">暂无符合条件的评论数据</p>
            </div>',
            $custom_title
        );
    }

    $html = '<div class="comment-rank-top">';
    $html .= sprintf('<h3 class="rank-top-title">%s</h3>', $custom_title);
    $html .= sprintf('<div class="rank-top-flex" style="--columns: %d;">', $columns);

    foreach ($top_users as $index => $user) {
        $comment_count = intval($user['comment_count']);
        $email = esc_attr($user['comment_author_email']);
        $name = esc_html($user['comment_author']);
        $url = esc_url($user['comment_author_url']);
        $rank = cur_get_user_rank($comment_count);

        $card_class = '';
        if ($index === 0) {
            $card_class = 'rank-card-1st';
            $rank_badge = '<span class="rank-top-badge rank-1st">🏆 第1名</span>';
        } elseif ($index === 1) {
            $card_class = 'rank-card-2nd';
            $rank_badge = '<span class="rank-top-badge rank-2nd">🥈 第2名</span>';
        } elseif ($index === 2) {
            $card_class = 'rank-card-3rd';
            $rank_badge = '<span class="rank-top-badge rank-3rd">🥉 第3名</span>';
        } else {
            $rank_badge = sprintf('<span class="rank-top-badge">第%d名</span>', $index + 1);
        }

        $avatar = get_avatar($email ?: $name, $avatar_size, '', $name, array(
            'class' => 'rank-top-avatar',
            'alt'   => $name . '的头像'
        ));

        $user_name_html = $url ? sprintf('<a href="%s" target="_blank" rel="nofollow">%s</a>', $url, $name) : $name;
        $rank_tag = sprintf('<span class="comment-user-rank %s">%s</span>', esc_attr($rank['class']), esc_html($rank['name']));

        $html .= sprintf(
            '<div class="rank-top-card %s">
                %s
                <div class="rank-top-card-inner">
                    <div class="rank-top-avatar-wrap" style="width: %dpx; height: %dpx;">%s</div>
                    <div class="rank-top-name">%s</div>
                    <div class="rank-top-meta">
                        %s
                        <span class="rank-top-count">评论数:%d</span>
                    </div>
                </div>
            </div>',
            $card_class,
            $rank_badge,
            $avatar_size,
            $avatar_size,
            $avatar,
            $user_name_html,
            $rank_tag,
            $comment_count
        );
    }

    $html .= '</div></div>';

    return $html;
}

add_shortcode('comment_rank_top', 'cur_render_rank_top');

css样式比较简单,这里就不贴出来了,大家可以根据自己的喜好制定自己喜欢的样式即可。

我这里给榜一、榜二和榜三的大佬添加不同的样式,比如给榜一、榜二和榜三的标签添加不同的颜色,给榜一、榜二和榜三的标签添加不同的图标,用来彰显三位大佬的身份。

展示效果大家可以在这个页面看到:https://www.lifengdi.com/comment-user-rank

简码用法如下:
简码:comment_rank_top
示例:[comment_rank_top num="10" columns="3" title="🔥 互动热榜"]
参数说明:

  • title: 排行榜标题(支持自定义,默认"评论等级排行榜")
  • columns: 列数(1~4,默认3)
  • num: 显示数量(默认10,最大50)
  • avatar_size: 头像尺寸(默认64px,最小32px)

大家有什么好的想法也可以提出来,我来负责实现。😉

除非注明,否则均为李锋镝的博客原创文章,转载必须以链接形式标明本文链接

本文链接:https://www.lifengdi.com/article/cha-jian/4626

相关文章

  • 做了一个WordPress文章热力图插件
  • WordPress评论添加UserAgent以及地理位置信息
  • 写了个日期进度条的小插件
  • Dylan Custom Plugin 1.0.3版本更新说明
  • Dylan Custom Plugin 1.0.2版本更新说明
本作品采用 知识共享署名-非商业性使用-相同方式共享 4.0 国际许可协议 进行许可
标签: PHP WordPress 排行榜 插件 评论
最后更新:2025年12月9日

李锋镝

既然选择了远方,便只顾风雨兼程。

打赏 点赞
< 上一篇
下一篇 >

文章评论

  • 彬红茶青铜友

    牛呀,一直在网上没有找到一个像样的,我的另一个网站可以试一下

    Android
    Chrome 99.0.4844.88 中国-广东-广州
    2026年1月11日
    回复
    • 李锋镝管理

      @彬红茶 我也是从网上没有找到想要的,哈哈哈

      Windows
      Chrome 143.0.0.0 中国
      2026年1月11日
      回复
  • 老张博客黑铁

    这个功能还是不错的,增强用户体验。还好我的主题是自带的。

    Windows
    Edge 143.0.0.0 美国
    2025年12月10日
    回复
    • 李锋镝管理

      @老张博客 还是主题自带的方便省事,而且契合主题

      macOS
      Chrome 142.0.0.0 中国-北京
      2025年12月10日
      回复
  • 不凡黑铁

    我看了下评论达人榜页面,第一名是你自己,应该排除网站管理员

    Windows
    Edge 141.0.0.0 中国-四川-内江
    2025年12月9日
    回复
    • 李锋镝管理

      @不凡 那个是之前不想登录后台回复评论用的一个账号,虽然名字是我,但是类型就是普通游客 :19:

      macOS
      Chrome 142.0.0.0 中国-北京
      2025年12月10日
      回复
  • 1 2 3 4 5 6 7 8 9 11 12 13 14 15 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 46 47 48 49 50 51 52 53 54 55 57 58 60 61 62 63 64 65 66 67 69 72 74 76 77 78 79 80 81 82 85 86 87 90 92 93 94 95 96 97 98 99
    取消回复

    秋天是倒放的春天,晚安是爱你的序篇。

    那年今日(02月10日)

    • 1953年:穆罕默德·纳吉布出任埃及总统
    • 1923年:德国物理学家、X射线发现者伦琴逝世
    • 1898年:德国戏剧家贝尔托·布莱希特出生
    • 1894年:英国政治家哈罗德·麦克米伦出生
    • 589年:杨坚灭陈朝,南北朝结束
    • 更多历史事件
    最新 热点 随机
    最新 热点 随机
    Apollo配置中心中的protalDB的作用是什么 org.apache.ibatis.plugin.Interceptor类详细介绍及使用 JDK25模块级导入深度解析:Java导入机制的革命性进化 AI时代,个人技术博客的出路在哪里? 什么是Meta Server? 千万级大表新增字段实战指南:告别锁表与业务中断
    玩博客的人是不是越来越少了?AI时代,个人技术博客的出路在哪里?准备入手个亚太的ECS,友友们有什么建议吗?使用WireGuard在Ubuntu 24.04系统搭建VPNWordPress实现用户评论等级排行榜插件WordPress网站换了个字体,差点儿把样式换崩了
    JWT、Cookie、Session、Token 区别与实战选型指南 Spring Boot 2.5.0重新设计的spring.sql.init 配置有啥用? 微服务的数据库设计 MySQL数据库详解——执行SQL更新时,其底层经历了哪些操作? AI重构开发者工作范式:从Anthropic内部调研看Claude对研发领域的深层影响 使用Spring MVC的websocket配置时 Tomcat启动报错
    标签聚合
    Spring K8s docker JAVA JVM 分布式 数据库 SpringBoot AI IDEA Redis 日常 AI编程 MySQL 多线程 SQL 设计模式 WordPress ElasticSearch 架构
    友情链接
    • Blogs·CN
    • Honesty
    • Mr.Sun的博客
    • 临窗旋墨
    • 哥斯拉
    • 彬红茶日记
    • 志文工作室
    • 懋和道人
    • 搬砖日记
    • 旧时繁华
    • 林羽凡
    • 瓦匠个人小站
    • 皮皮社
    • 知向前端
    • 蜗牛工作室
    • 韩小韩博客
    • 风渡言

    COPYRIGHT © 2026 lifengdi.com. ALL RIGHTS RESERVED.

    域名年龄

    Theme Kratos Made By Dylan

    津ICP备2024022503号-3

    京公网安备11011502039375号