WordPress极简博客 WordPress极简博客
  • 新鲜事
  • 战疫情
  • UI素材
    • UI素材
    • 电商/节日
    • PPT
      • 节日庆典
      • 工作汇报
      • 商业计划书
    • word
      • 简历竞聘
      • 合同/公文
  • 创客头条
    • 音乐分享
    • 初创文章
    • 极客头条
    • 生活趣事
    • 生活日记
    • 防骗指南
  • 编程教学
    • API日记
    • Linux安全栏目
      • Linux运维安全汇总
      • DDOS攻击防护
      • XSS攻击防护
      • SQL安全防护
    • Python技术栏目
      • Python基础入门
      • Python基础结构
    • WordPress技术栏目
      • WP主题
      • WordPress技术教程
      • RIPRO主题美化
    • WordPress漏洞发布
    • 技术教程汇总
    • 严选源码
  • 专题
  • 基友
  • 隐私
  • 注册
    登录
立即登录
  • 首页
  • 云优化
  • 新疫情
  • 新鲜事
    • 热文
    • 极客
    • 生活
  • 技术篇
    • WP主题
    • 技术教程
    • Python入门
    • Python基础
  • 专题篇
  • 友链君
首页 技术教程(干货) WordPress纯代码实现ajax评论无限加载教程

WordPress纯代码实现ajax评论无限加载教程

夏柔 4月 19, 2020

https://www.wpon.cn/

评论AJAX加载方式的优点在于用户体验,不用点击翻译,但是个人觉得一般站点的评论也没有多少,更不说需要翻页的。

所以博主没有采用评论无限加载,但是或许有人喜欢那?

所以今天就分享一篇实现ajax评论无限加载的WordPress教程,最终效果如下图所示:

WordPress纯代码实现ajax评论无限加载教程-WordPress极简博客

在使用AJAX加载评论时,需要在后台设置-评论设置,进行如下的设置(其中每页显示评论数量可以根据你的需要自定义)。

 

WordPress纯代码实现ajax评论无限加载教程-WordPress极简博客

 

添加“加载更多”按钮

首先在你在主题中查找评论分页功能paginate_comments_links()函数,并将其替换为以下代码。若找不到此函数,请在代码< ol class="comment-list">...< /ol >后面放置代码

$cpage = get_query_var('cpage') ? get_query_var('cpage') : 1;




if( $cpage > 1 ) {

echo '<div class="comment_loadmore">More comments</div>

<script>

var ajaxurl = \'' . site_url('wp-admin/admin-ajax.php') . '\',

   parent_post_id = ' . get_the_ID() . ',

       cpage = ' . $cpage . '

</script>';

}

由于默认显示最后的评论页面,$cpage所以等于注释页面的最大数量。条件if( $cpage > 1 ) {意味着两件事情同时发生 - 在下列情况下输出加载更多按钮和脚本。

无限加载 jQ

首先我们创建一个ajax-comment.js文件并复制下面的代码到js文件中。

jQuery(function($){

        //加载更多按钮点击事件 

$('.comment_loadmore').click( function(){

var button = $(this);

                //减少当前评论页面的值 

cpage - ;

$.ajax({

url : ajaxurl, 

data : {

'action': 'cloadmore', 

'post_id': parent_post_id,//当前文章

'cpage' : cpage,//当前评论页

},

type : 'POST',

beforeSend : function ( xhr ) {

button.text('加载中...'); 

},

success : function( data ){

if( data ) {

$('ol.comment-list').append( data ); 

button.text('加载更多');

                                       //如果最后一页,则删除按钮

if ( barley.cpage == 1 ) 

button.remove();

} else {

button.remove();

}

}

});

return false;

});




});

这里减少cpage了的值,因为评论页以降序显示。接着就是加载这个JQ到页面,这里就不详细说了

实现功能

最后我们在functions.php中插入下面代码 :

add_action('wp_ajax_cloadmore', 'comments_loadmore_handler'); // wp_ajax_{action}

add_action('wp_ajax_nopriv_cloadmore', 'comments_loadmore_handler'); // wp_ajax_nopriv_{action}




function comments_loadmore_handler(){




global $post;

$post = get_post( $_POST['post_id'] );

setup_postdata( $post );




wp_list_comments( array(

'avatar_size' => 100,

'page' => $_POST['cpage'], 

'per_page' => get_option('comments_per_page'),

'style' => 'ol', 

'short_ping' => true,

'reply_text' => '回复',

) );

die;

}

 

1
J2dcg1.png
猜你喜欢
  • Nginx添加跨域限制规则
  • 使用测速脚本对国内Linux服务器进行测速
  • 域名爆破之自动化信息收集脚本
  • 利用免费接口实现国家开放大学刷网课脚本
  • RiProV2定制导航条
  • 判断是否在微信浏览器打开
  • 微信内自动播放音频非百度方案
  • 利用veImageX加速您的网站,想不快都难!
  • SWAPIDC减少注册信息及防刷注册量教学
  • Python实现定时发送每日早报及生活指数
08 6月, 2020
如何使用Nginx缓存加速WordPRess网站
夏柔
站长
夏山如碧 - 怀柔天下
1700
文章
25
评论
58145K
获赞
版权声明

文章采用创作共用版权 CC BY-NC-ND/2.5/CN 许可协议,与本站观点无关。

如果您认为本文侵犯了您的版权信息,请与我们联系修正或删除。
投诉邮箱wpsite@aliyun.com

栏目推荐
Python基础入门33
WordPress技术教程267
前沿技术情报所22
城市创新——新消费11
最近有哪些不可错过的热文23
程序员的养生之道0
节
春
  • 新鲜事
  • 疫情实况
  • UI素材
  • 技术教程
  • 音乐分享
  • 专题
  • 友情
  • 隐私
  • 云优化
Copyright © 2019-2025 WordPress极简博客. Designed by 夏柔. 辽公网安备21010502000474号 辽ICP备19017037号-2