WordPress 5.1评论回复按钮失效评论框不跟随怎么办?

投稿   懿古今  2019-03-17 09:02:47  320 人阅读  23 条评论

懿古今博客升级到 5.1.1 已经有一段时间了,但是一直都没留意到点击评论回复会有问题,今早无意间发现点击【回复】不单是评论框不出现还会刷新当前页面无法直接恢复,在主题没有修改的情况下出现这种问题估计是 WordPress 升级所致,网络上搜索一番发现果然是 WordPress 5.1 搞得鬼,原来是 5.1 更改了的 wp-includes\comment-template.php 文件的 get_comment_reply_link()函数,5.0 及以前的版本,该函数输出评论回复链接按钮是绑定有一个 onclick,具体以下代码:

$onclick = sprintf( 'return addComment.moveForm( "%1$s-%2$s", "%2$s", "%3$s", "%4$s" )',
$args['add_below'], $comment->comment_ID, $args['respond_id'], $post->ID
);

而 5.1 版本之后就没有这个 onclick。具体见以下对比图:

WordPress 5.1评论回复按钮失效评论框不跟随怎么办? WordPress 第1张

问题发现是那么解决起来就简单多了,根据『樱花庄的白猫』博主提供的修复方案,就是为评论回复按键 reply 添加一个 click 事件监听器,用 jQuery 实现即可。如果你使用的是 Nana 主题或 WordPress 版本的 Blogs 主题,那么直接打开主题文件 js\script.js 文件,找到以下代码:

$(document).ready(function(){
// 移动端输入页码跳转

修改为

$(document).ready(function(){
$('body').on('click', '.comment-reply-link', function(){
addComment.moveForm( "div-comment-"+$(this).attr('data-commentid'), $(this).attr('data-commentid'), "respond", $(this).attr('data-postid') );
return false; 
});
// 移动端输入页码跳转

即可。

其他主题的,请自行添加以下 JS 代码到当前主题的 JS 文件即可:

$('body').on('click', '.comment-reply-link', function(){
addComment.moveForm( "comment-"+$(this).attr('data-commentid'), $(this).attr('data-commentid'), "respond", $(this).attr('data-postid') );
return false; // 阻止 a tag 跳转,这句千万别漏了
});

修复方法及代码来自@樱花庄的白猫

注意:comment-要与主题的评论结构一直,比如有些主题就是 comment-评论 ID,懿古今主题就是 div-comment-评论 ID,如果不一致评论框就嵌套不到评论内容下方哦。

根据知更鸟和张戈两位大神给出了一个更简单的办法,分为 begin 主题或非 begin 主题,如果你也遇到这种问题的,不妨试试下面这种方法。

如果是 begin 主题,直接在 functions.php 里面找到:zmingcx_scripts 函数,在最后一个 } 之前加上:

// 加载回复 js
if ( is_singular() && comments_open() && get_option( 'thread_comments' ) ) {
wp_enqueue_script( 'comment-reply' );
}

这段代码其实就是在页面加载一段 JS:

<script type='text/javascript' src='/wp-includes/js/comment-reply.min.js?ver=5.1.1'></script>

所以,非 begin 主题,只需要在主题的 header.php 加上如下代码即可:

<?php if ( is_singular() && comments_open() && get_option( 'thread_comments' ) ) { ?>
<script type='text/javascript' src='/wp-includes/js/comment-reply.min.js?ver=5.1.1'></script>
<?php } ?>

这样就问题就解决了!

答案来自@张戈博客

您可能感兴趣的文章

文章标签: ,  
原文地址:https://www.yigujin.cn/1902.html
温馨提示:文章内容仅代表作者个人观点,不代表boke112导航赞同其观点和对其真实性负责!
版权声明:本文为投稿文章,感谢 懿古今 的投稿,版权归原作者所有,欢迎分享本文,转载请保留出处!
©boke112导航,本站推荐使用:阿里云 ECS服务器等云产品服务,国外免备案主机建议使用:老薛主机
懿古今

 发表评论

强表情无奈表情抠鼻表情笑哭表情偷笑表情衰表情流汗表情奋斗表情吐血表情抓狂表情晕表情流泪表情疑问表情呲牙表情惊讶表情鼓掌表情

  1. 讯沃blog
    讯沃blog @回复

    支持下,改了就能用了 [呲牙]

  2. 明月登楼的博客
    明月登楼的博客 @回复

    我说呢,原来是WordPress 5.1闹得鬼! [衰] [流汗] [笑哭]

  3. 驿站
    驿站 @回复

    升级需慎重 [笑哭]

  4. 唯心寒辞
    唯心寒辞 @回复

    不知道为什么自动升级不了,只能手动升级了5.1.1,倒是没注意到这个问题

  5. 值品
    值品 @回复

    厉害了,我的是自动升级,什么时候升级了都没注意。 [笑哭]

  6. 猫鼬
    猫鼬 @回复

    一直不敢点升级,漏洞安全和兼容问题不可兼得啊。

  7. 时光在路上
    时光在路上 @回复

    没有那么复杂呀,在主题 functions.php 中添加如下代码即可,亲测可行:

    if ( is_singular() && comments_open() && get_option( ‘thread_comments’ ) ) {
    wp_enqueue_script( ‘comment-reply’ );
    }

  8. 投资巴士
    投资巴士 @回复

    没遇到过,也看不大懂,但是先存着!万一以后用到了,呵呵

  9. 子午物联网
    子午物联网 @回复

    不升级是不是就不用担心后续的问题了,我还停留在很老的版本