李锋镝的博客

  • 首页
  • 时间轴
  • 左邻右舍
  • 关于我
    • 关于我
    • 另一个网站
    • 我的导航站
    • 网站地图
    • 赞助
    • 博友圈
  • 说说
  • 走心评论
  • 互动榜
  • 留言
  • 🚇开往
Destiny
自是人生长恨水长东
  1. 首页
  2. 原创
  3. WordPress
  4. 正文

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

2025年12月9日 884点热度 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/wordpress/4626

相关文章

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

李锋镝

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

打赏 点赞
< 上一篇
下一篇 >
1234567891112131415161718192021222324252627282930313233343536373839404142434446474849505152535455575859606162636465666769727476777879808182858687909293949596979899
取消回复
…

文章评论

  • 彬红茶Lv 2友链

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

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

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

      WindowsChrome 143.0.0.0 中国-北京市
      2026年1月11日
      回复
  • 老张博客Lv 2

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

    WindowsEdge 143.0.0.0 加拿大-Toronto
    2025年12月10日
    回复
    • 李锋镝管理

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

      macOSChrome 142.0.0.0 中国-北京市
      2025年12月10日
      回复
  • 不凡Lv 1

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

    WindowsEdge 141.0.0.0 中国-成都市
    2025年12月9日
    回复
    • 李锋镝管理

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

      macOSChrome 142.0.0.0 中国-北京市
      2025年12月10日
      回复
  • 秋天是倒放的春天,晚安是爱你的序篇。

    那年今日(07月03日)

    • 2005年:西班牙正式通过同性婚姻相关法案
    • 1969年:英国滚石乐队的创始团员布莱恩·琼斯去世
    • 1876年:中国第一条铁路淞沪铁路正式通车运营
    • 1518年:中国明代医学家兼药物学家李时珍出生
    • 1062年:中国北宋官员包拯去世
    • 更多历史事件
    最新 热点 随机
    最新 热点 随机
    Kratos+主题新功能预览及功能演示 SpringBoot DeferredLog 完整详解 LiteLLM 本地代理搭建 Claude-HUD 使用文档 Kratos+ —— Kratos 主题二次开发记录 译文:如何将单体应用拆解为微服务
    AI时代,个人技术博客的出路在哪里?这个域名注册整整十年了,十年时间,真快啊WordPress实现用户评论等级排行榜插件WordPress网站换了个字体,差点儿把样式换崩了做了一个WordPress文章热力图插件千万级大表新增字段实战指南:告别锁表与业务中断
    Auld Lang Syne 缓存架构实战指南:6大核心缓存技术深度解析与落地方案 阿里巴巴的26款超神Java开源项目 Claude Code全维度实战指南:从入门到精通,解锁AI编程新范式 岁末 海琴烟~~~
    最近评论
    李锋镝 发布于 4 天前(06月30日) 目前是每天一换,一个星期不重样 :41:
    不凡 发布于 4 天前(06月29日) 主题配色挺好看。 :2:
    李锋镝 发布于 5 天前(06月29日) 已经更新了~
    懋和道人 发布于 5 天前(06月29日) 境外与附件不能访问,其他都是正常的,如果不正常可以通过更换ip访问。
    李锋镝 发布于 5 天前(06月29日) 403呀道长
    标签聚合
    SQL 多线程 日常 IDEA 数据库 ElasticSearch Spring AI编程 JVM JAVA SpringBoot MCP 分布式 MySQL docker AI 架构 K8s Redis WordPress
    友情链接
    • Blogs·CN
    • Honesty
    • Mr.Sun的博客
    • 临窗旋墨
    • 哥斯拉
    • 彬红茶日记
    • 志文工作室
    • 懋和道人
    • 拾趣博客导航
    • 搬砖日记
    • 旧时繁华
    • 林羽凡
    • 瓦匠个人小站
    • 皮皮社
    • 知向前端
    • 蜗牛工作室
    • 韩小韩博客
    • 风渡言

    COPYRIGHT © 2026 lifengdi.com. ALL RIGHTS RESERVED.

    域名年龄

    Theme Kratos+ By Dylan Li

    津ICP备2024022503号-3

    京公网安备11011502039375号