前言
在逛不亦乐乎博客时,我被其留言页面上读者墙的样式深深吸引。此外,在wys的友链页面,我也看到了独特的样式,这让我心痒难耐。于是,我开始在网上搜索相关的信息,偶然发现了张戈博客之前写过的一个插件。虽然这个插件由于年代久远已不再适用,但我决定根据其代码进行修改,并将其实现到自己的博客中。
步骤
1. 添加代码至 functions.php
首先,在你博客的主题目录下找到并打开 functions.php
文件。然后,将以下代码添加到文件末尾:
// 注册并加载读者墙的CSS样式 function enqueue_readers_wall_styles() { global $post; if (is_a($post, 'WP_Post') && has_shortcode($post->post_content, 'readers_wall')) { wp_enqueue_style('readers-wall-style', get_template_directory_uri() . '/css/readers-wall.css', array(), '1.0.0'); } } add_action('wp_enqueue_scripts', 'enqueue_readers_wall_styles'); // 辅助函数:生成排行列表 function generate_readers_list($title, $query, $limit) { global $wpdb; $output = ''; // 使用 transient 缓存查询结果 $transient_key = 'readers_wall_' . md5($query); $wall = get_transient($transient_key); if (false === $wall) { $wall = $wpdb->get_results($query); set_transient($transient_key, $wall, 3600); } $output .= '<div class="readers-section">'; $output .= '<h2 class="entry-title">' . esc_html($title) . ' TOP' . esc_html($limit) . '</h2>'; if ($wall) { $output .= "<ul class='readers-list'>"; foreach ($wall as $comment) { $avatar = get_avatar($comment->comment_author_email, 64, '', '', array('loading' => 'lazy')); $url = esc_url($comment->comment_author_url ? $comment->comment_author_url : "#"); $author = esc_html($comment->comment_author); $count = intval($comment->cnt); // 用作者名称替代邮箱作为 tooltip 的 ID $tooltip_id = sanitize_title($author); $tooltip = "{$author}<br>评论数: {$count}"; $output .= "<li> <a rel='friend' target='_blank' href='{$url}' aria-describedby='tooltip-{$tooltip_id}'> {$avatar} <div class='tooltip' id='tooltip-{$tooltip_id}' role='tooltip'>{$tooltip}</div> </a> </li>"; } $output .= "</ul>"; } else { $output .= "<p>没有找到" . esc_html($title) . "数据。</p>"; } $output .= '</div>'; return $output; } // 短代码函数:读者墙 function readers_wall_shortcode() { global $wpdb; $output = ''; // 评论总排行榜 $query2 = $wpdb->prepare( "SELECT COUNT(comment_ID) AS cnt, comment_author, comment_author_url, comment_author_email FROM $wpdb->comments LEFT JOIN $wpdb->posts ON ($wpdb->posts.ID = $wpdb->comments.comment_post_ID) WHERE post_password = '' AND comment_approved = '1' AND comment_author != %s GROUP BY comment_author_email ORDER BY cnt DESC LIMIT %d", '段先森', 12 ); $output .= generate_readers_list('评论总排行榜', $query2, 12); // 年度评论排行 $query1 = $wpdb->prepare( "SELECT COUNT(comment_ID) AS cnt, comment_author, comment_author_url, comment_author_email FROM ( SELECT * FROM $wpdb->comments LEFT JOIN $wpdb->posts ON ($wpdb->posts.ID = $wpdb->comments.comment_post_ID) WHERE comment_date BETWEEN DATE_SUB(NOW(), INTERVAL 1 YEAR) AND NOW() AND post_password = '' AND comment_approved = '1' AND comment_author != %s ) AS tempcmt GROUP BY comment_author_email ORDER BY cnt DESC LIMIT %d", '段先森', 365 ); $output .= generate_readers_list('年度评论排行', $query1, 365); // 本月评论排行 $query2 = $wpdb->prepare( "SELECT COUNT(comment_ID) AS cnt, comment_author, comment_author_url, comment_author_email FROM ( SELECT * FROM $wpdb->comments LEFT JOIN $wpdb->posts ON ($wpdb->posts.ID = $wpdb->comments.comment_post_ID) WHERE DATE_FORMAT(comment_date, '%%Y-%%m') = DATE_FORMAT(NOW(), '%%Y-%%m') AND post_password = '' AND comment_approved = '1' AND comment_author != %s ) AS tempcmt GROUP BY comment_author_email ORDER BY cnt DESC LIMIT %d", '段先森', 31 ); $output .= generate_readers_list('本月评论排行', $query2, 31); // 本周评论排行 $query3 = $wpdb->prepare( "SELECT COUNT(comment_ID) AS cnt, comment_author, comment_author_url, comment_author_email FROM ( SELECT * FROM $wpdb->comments LEFT JOIN $wpdb->posts ON ($wpdb->posts.ID = $wpdb->comments.comment_post_ID) WHERE YEARWEEK(DATE_FORMAT(comment_date, '%%Y-%%m-%%d')) = YEARWEEK(NOW()) AND post_password = '' AND comment_approved = '1' AND comment_author != %s ) AS tempcmt GROUP BY comment_author_email ORDER BY cnt DESC LIMIT %d", '段先森', 7 ); $output .= generate_readers_list('本周评论排行', $query3, 7); return $output; } add_shortcode('readers_wall', 'readers_wall_shortcode');
2. 创建 CSS 文件
在你主题的目录下,找到
css
文件夹,并新建一个名为 readers-wall.css
的文件。将以下样式代码粘贴到该文件中:/* readers-wall.css */ /* 容器样式 */ .readers-section { margin-bottom: 30px; } .readers-section h2.entry-title { font-size: 24px; margin-bottom: 15px; color: #333; } /* 头像列表样式 */ .readers-list { display: flex; flex-wrap: wrap; list-style: none; padding: 0; margin: 0; } .readers-list li { position: relative; margin: 10px; width: 50px; /* 调整头像大小 */ height: 50px; } .readers-list li a { display: block; width: 100%; height: 100%; text-align: center; text-decoration: none; position: relative; } .readers-list li img { width: 100%; height: 100%; border-radius: 50%; box-shadow: 0 2px 5px rgba(0, 0, 0, 0.1); transition: transform 0.3s ease; } .readers-list li a:hover img, .readers-list li a:focus img { transform: scale(1.1); } /* 悬停信息框样式 */ .readers-list li .tooltip { visibility: hidden; opacity: 0; width: 160px; background-color: rgba(0, 0, 0, 0.75); color: #fff; text-align: center; border-radius: 6px; padding: 8px; position: absolute; bottom: 60px; /* 头像上方 */ left: 50%; transform: translateX(-50%); transition: opacity 0.3s ease; z-index: 10; font-size: 14px; } .readers-list li .tooltip::after { content: ""; position: absolute; top: 100%; /* 箭头指向头像 */ left: 50%; margin-left: -5px; border-width: 5px; border-style: solid; border-color: rgba(0, 0, 0, 0.75) transparent transparent transparent; } .readers-list li:hover .tooltip, .readers-list li a:focus .tooltip { visibility: visible; opacity: 1; } /* 响应式设计 */ @media (max-width: 600px) { .readers-list li { width: 40px; height: 40px; } .readers-section h2.entry-title { font-size: 20px; } .readers-list li .tooltip { width: 140px; font-size: 12px; } }
3. 新建页面并插入简码
在你的 WordPress 后台,创建一个新页面或编辑现有页面,并插入以下简码:
readers_wall
结尾
以上就是我在个人博客上实现自定义读者墙功能的步骤。如果你希望根据自己的需求进行样式调整,可以随意修改 readers-wall.css
中的 CSS 代码,
感谢 maie 的提醒,已修改funtions.php相关代码,隐藏邮箱地址。新增评论排行总榜
水八口 ( VIP 1 )
中国江苏怀念起我的WP时光,也搞过读者墙哈哈!
段先森
中国陕西@水八口 哈哈,重走来时路
粽叶加米 ( VIP 5 )
亚太地区真不错,我还上榜单了。
段先森
中国甘肃@粽叶加米 哈哈,多来必站榜首
wys ( VIP 1 )
中国宁夏哈哈,被点名了。。
//近两天还在啃初试笔记(/114.html),以至于今儿再次看到“三无青年”站名时,不自觉地就把“三无”与刚看过笔记里的“三无”进行匹配了:
三无:⑴无法定扶养人,或者虽有法定扶养人,但是扶养义务人无扶养能力的;⑵无劳动能力的;⑶无生活来源的。(《2021 社会工作实务(中级)》-p169)
段先森
中国甘肃@wys 啊哈,哈哈哈,我的三无是网络定义
小陈故事 ( VIP 3 )
中国重庆博客写着写着,就都成技术员了。
段先森
中国甘肃@小陈故事 哈哈,说的没错
acevs ( VIP 2 )
美国这个好。我来上墙。多留言。
段先森
美国@acevs 必须上墙,嘿嘿
Kevin's ( VIP 2 )
中国香港okok,空了我也搞一个!!估计就是最近了,我先换个首页去
段先森
美国@Kevin's 赶紧换,然后写教程咯
老麦 ( VIP 6 )
中国广东怎么每次进来的主题都不一样的呢,哈哈哈。
这样的功能能有效的提升博友间的互动,赞一个。
段先森
美国@老麦 嘿嘿,换主题第一人非我莫属
Liudon ( VIP 1 )
中国北京我记得wordpress支持钩子的吧,你这样后续升级有点麻烦吧
段先森
中国甘肃@Liudon 兴趣使然,准备弄成插件形式,修改张戈博客的插件
Liudon ( VIP 1 )
中国北京@段先森 你的邮件通知里点击的链接是空的
段先森
中国甘肃@Liudon 好的吧,我去看真是如此
大峰 ( VIP 6 )
中国江苏看着很溜啊,双击666。
段先森
中国甘肃@大峰 哈哈,必须溜
竹语随风 ( VIP 1 )
中国湖北厉害 前来膜拜大佬
段先森
中国甘肃@竹语随风 ai是非常强大的,哈哈
wu先生 ( VIP 3 )
亚太地区不明觉历哈。
段先森
中国甘肃@wu先生 哈哈,
逐风 ( VIP 1 )
中国四川又换主题了哇? 这个主题蛮简洁嘞,好看!
段先森
中国甘肃@逐风 还可以,各有各的好处,哈哈
Jeffer.Z ( VIP 2 )
中国北京如果是wordpress可以给没有头像的人,设置一个默认头像,不然一堆无头像的堆里面不好看,我首页就是一个读者墙,特意加了个超链接,方便博友互相串门。😁
段先森
中国甘肃@Jeffer.Z 可以调用本地静态,我没弄,我这是显示的太多了,哈哈
落落vici ( VIP 1 )
中国广东那个词叫啥来着,狂炫酷拽吊炸天。
段先森
俄罗斯@落落vici 哈哈,炸天帮嘛
土拨许 ( VIP 2 )
中国安徽刚好需要一个类似的功能̋(ˊ•͈ꇴ•͈ˋ)
段先森
俄罗斯@土拨许 那就赶紧来吧
冰剑 ( VIP 2 )
中国湖北想起了以前弄得血条墙。
段先森
中国甘肃@冰剑 就是根据那个改的,哈哈
老狼 ( VIP 3 )
中国广东对于评论活跃的博客,更有意义,其他都是浮云
段先森
中国甘肃@老狼 确实呢,嘿嘿
网友小宋 ( VIP 6 )
中国河南年度咱上排行榜了,不过handsome好像自带的有。
段先森
中国甘肃@网友小宋 嘿嘿,榜一大哥来咯,handsome主题确实自带,所以说他优秀嘛,哈哈
老张博客 ( VIP 6 )
中国江苏我的广场被我调好了,来试试呀。
段先森
中国甘肃@老张博客 加入白名单了嘛,我去看看
maie ( VIP 2 )
中国四川看起来有点意思
段先森
中国甘肃@maie 嘿嘿,想一出是一出,瞎折腾
maie ( VIP 2 )
中国四川@段先森 貌似页面头像处html会泄漏邮箱,建议修改优化一下
段先森
中国甘肃@maie 咦,感谢提醒,已优化
茗总 ( VIP 1 )
中国新疆哎呦不错哦
段先森
中国甘肃@茗总 感谢夸奖,哈哈哈哈
zwwooooo ( VIP 2 )
中国广东现在还在坚持博客的人很少,能评个论的更少,像我偶尔还会回访的甚少
段先森
中国甘肃@zwwooooo 哈哈,确实呢,都是熟悉的才会呢
土拨许 ( VIP 2 )
中国安徽@zwwooooo 大佬啊,上初中就经常去看的博客。
皇家元林 ( VIP 3 )
中国安徽你这个文章里显示代码这段用的什么插件?很好看啊!
你是用经典编辑器还是区块编辑器?
段先森
中国甘肃@皇家元林 用的经典,不过代码高亮是主题自带的呢
Evan ( VIP 2 )
中国北京搞定了,不过不同浏览器中样式还是会有不同,现在 Chrome中表现最好 ^_^
https://www.evan.xin/say/
段先森
中国甘肃@Evan 可以的呀,可以尝试头像圆角化
Evan ( VIP 2 )
中国北京@段先森 不知道怎么设置,这个要改CSS里面的代码吧。
段先森
中国甘肃@Evan 是的呢,我的代码里有,应该跟你的主题没有适配,你可以调整一下css代码
Evan ( VIP 2 )
中国北京@段先森 是的,我看了设置里面,你这个代码确实已经是圆形了,但是在这个主题里面是不起作用的。我暂时不知道改pix主题的什么位置。抽时间再找找
Evan ( VIP 2 )
中国北京@段先森 现在的效果跟你的一样了。哈哈。我用了!important 保证了优先级,然后就解决了。哈哈哈哈
阿杰 Jack ( VIP 1 )
中国上海挺有意思的~
段先森
中国甘肃@阿杰 Jack 嘿嘿,自己弄起来确实挺有意思的呢
Evan ( VIP 2 )
中国北京这下可以看到了吧。。晕倒。
段先森
美国@Evan 你第一条评论的就可以看到图片啊。横线是在一个容器里。还有你说的小圈圈都可以用css代码解决
Evan ( VIP 2 )
中国北京@段先森 不太懂,代码。。我找找。。
Evan ( VIP 2 )
中国北京这个图片上的小横线和小圈圈。。。
Evan ( VIP 2 )
中国北京对了,前面的小圈圈。。也是。。我这个怎么跟你的现实不一样啊。
Evan ( VIP 2 )
中国北京这个下面的横线,如何去掉???
Lvtu ( VIP 6 )
中国广东优秀。。。
段先森
伊朗@Lvtu 嘿嘿
obaby ( VIP 5 )
中国山东这个不错,等找时间抄作业
段先森
伊朗@obaby 嘿嘿,对于你来说易如反掌
耳朵的主人 ( VIP 1 )
中国福建@obaby 我晚上就开抄,哈哈,好久没有折腾拓展功能了。
这有完整教学,拿来主义。哈哈
明明同学 ( VIP 1 )
中国江苏博主这个动手能力好强
段先森
中国甘肃@明明同学 一动起念头就想立刻实现它,嘿嘿
满心 ( VIP 1 )
中国湖北牛逼,这个不错
段先森
中国甘肃@满心 哈哈,gpt分分钟