2023纯代码实现WordPress文章内容评论回复可见

“WordPress文章内容评论回复可见”这个功能很常见了,许多主题都集成了这个功能,然后WordPress也有相应的插件来实现。但地质网目前所使用的的document主题并未集成该功能,而老白自己是最不喜欢用插件的。因此接下来就跟大家说一下如何用纯代码实现该功能(踩的坑)

2023纯代码实现WordPress文章内容评论回复可见

1.评论可见功能代码

代码来源是一位大佬开发的插件,插件地址:https://gitee.com/fangxiansheng123/fb-reply

然后我做了一点简单的修改,免插件纯代码实现

代码如下(顺便演示功能),加到主题文件的function.php底部:

①优点

  • 免注册,访客评论也可立马刷新
  • 已注册用户会记录cookie,一直可见

②注意事项

这里有个地方需要注意,原代码点击“评论”后跳转的链接是

2023纯代码实现WordPress文章内容评论回复可见

就是你该文章的评论区,但是这个锚点(#respond),每个WordPress主题可能是不一样的,我的主题就是(?replytocom)

2023纯代码实现WordPress文章内容评论回复可见

③使用方法

在文章中用下面短代码包裹需要隐藏的内容即可

2023纯代码实现WordPress文章内容评论回复可见

在文本模式和代码模式下均可

2.简单美化修改

①添加短代码到编辑器

同理,添加到function文件

2023纯代码实现WordPress文章内容评论回复可见

// 添加评论回复按钮到HTML编辑器-https://www.dzw6.com/29710.html
add_action('after_wp_tiny_mce', 'add_custom_button_mce');
function add_custom_button_mce($mce_settings) {
    ?>
    <script type="text/javascript">
        QTags.addButton('reply', 'reply', '
'); </script> <?php }

②样式简单修改

这个代码在上面中包含了,大家此处仅看修改后的即可,不用再添加

此处就是css调整为居中显示

    .reply-to-read{
        display: flex;
        align-items: center;
        justify-content: center;

③登录用户免评论可见

(这个功能未在地质网开启,大家自行测试下)

修改auto_reply()函数,在函数中判断是否有登录用户,并设置一个名为fbreply的cookie。

function auto_reply($comment_id, $comment_object) {
if (is_user_logged_in()) {
setcookie("fbreply", "1");
}
}

修改reply_to_read()函数,在函数中先检查登录用户是否已经设置了fbreply的cookie,如果是则直接返回内容,否则返回隐藏提示信息

function reply_to_read($atts, $content=null) {
    extract(shortcode_atts(array("notice" => '<div class="reply-to-read"><p><strong>此处为隐藏内容,您需要<a href="' . wp_login_url() . '">登录</a>后才能查看</strong></p></div>'), $atts));
    
    if (is_user_logged_in() || $_COOKIE['fbreply'] == "1") {
        return do_shortcode($content);
    } else {
        return $notice;
    }
}

④管理员免评论可见

同理,和③类似的

function auto_reply($comment_id, $comment_object) {
    if (is_user_logged_in()) {
        setcookie("fbreply", "1");
    }
}

修改reply_to_read()函数

function reply_to_read($atts, $content=null) {
    extract(shortcode_atts(array("notice" => '<div class="reply-to-read"><p><strong>此处为隐藏内容,您需要<a href="' . wp_login_url() . '">登录</a>后才能查看</strong></p></div>'), $atts));
    
    if (is_user_logged_in() || $_COOKIE['fbreply'] == "1") {
        return do_shortcode($content);
    } else {
        return $notice;
    }
}

给TA打赏
共{{data.count}}人
人已打赏
网站建设

WordPress7B2主题个人中心页面的美化解读

2023-9-8 20:52:50

网站建设

个人常用命令/资料集合

2023-9-12 8:40:28

🚨 小黑屋
  1. 看看这个功能

  2. 看看

  3. 太棒了,谢谢楼主的分享

    • 都是基于大佬的插件,适配问题就关注评论区锚点即可

  4. 老白

    测试看看

  5. 老白

    thanks,you can use some Translation Plugin,it helps a lot!

个人中心
购物车
优惠劵
今日签到
有新私信 私信列表
搜索