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

2019年03月17日 08:57:02  阅读 56 次 评论 4 条

懿古今博客升级到 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评论回复按钮失效评论框不跟随怎么办? 技术文档 第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,如果不一致评论框就嵌套不到评论内容下方哦。

历史上的今天:

文章标签: ,  
本文地址:https://www.yigujin.cn/1902.html
版权声明:本文为原创文章,版权归 懿古今 所有,欢迎分享本文,转载请保留出处!
NEXT已经是最新一篇了
©懿古今博客,本站推荐使用:阿里云腾讯云 的服务器等云产品,免备案主机建议使用:老薛主机

相关文章 分类热门分类热评随机文章

发表评论

中国赞表情摊手表情吃瓜表情笑哭表情偷笑表情衰表情汗表情思考表情费解表情抓狂表情晕表情流泪表情疑问表情嘻嘻表情吃惊表情鼓掌表情

表情

  1. 贵安服贸
    贵安服贸 @回复

    感谢博主,学习了

  2. 红嘴鸭
    红嘴鸭 @回复

    大佬就是大佬 不愧为专业的

  3. 青山
    青山 @回复

    这好像是那啥ajax问题吧

    • 懿古今
      懿古今2019-03-18 16:20  回复

      @青山不管是什么问题,反正解决了就不管它了。5.0及以前的版本都没有问题