WordPress教程

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

阿里云

评论 AJAX 加载方式的优点在于用户体验,不用点击翻译,但是个人觉得一般站点的评论也没有多少,更不说需要翻页的。所以博主没有采用评论无限加载,但是或许有人喜欢那?所以今天就分享一篇实现 ajax 评论无限加载的 WordPress 教程,最终效果如下图所示:

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

添加“加载更多”按钮

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

也想出现在这里?联系我们
创客主机
  1. $cpage = get_query_var('cpage') ? get_query_var('cpage') : 1;
  2.  
  3. if( $cpage > 1 ) {
  4. 	echo '<div class="comment_loadmore">More comments</div>
  5. 	<script>
  6. 	var ajaxurl = \'' . site_url('wp-admin/admin-ajax.php') . '\',
  7. 	    parent_post_id = ' . get_the_ID() . ',
  8.     	    cpage = ' . $cpage . '
  9. 	</script>';
  10. }

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

无限加载 jQuery

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

  1. jQuery(function($){
  2.         //加载更多按钮点击事件 
  3. 	$('.comment_loadmore').click( function(){
  4. 		var button = $(this);
  5.                 //减少当前评论页面的值 
  6. 		cpage - ;
  7. 		$.ajax({
  8. 			url : ajaxurl, 
  9. 			data : {
  10. 				'action': 'cloadmore', 
  11. 				'post_id': parent_post_id,//当前文章
  12. 				'cpage' : cpage,//当前评论页
  13. 			},
  14. 			type : 'POST',
  15. 			beforeSend : function ( xhr ) {
  16. 				button.text('加载中...'); 
  17. 			},
  18. 			success : function( data ){
  19. 				if( data ) {
  20. 					$('ol.comment-list').append( data ); 
  21. 					button.text('加载更多');
  22.                                        //如果最后一页,则删除按钮
  23. 					if ( barley.cpage == 1 ) 
  24. 						button.remove();
  25. 				} else {
  26. 					button.remove();
  27. 				}
  28. 			}
  29. 		});
  30. 		return false;
  31. 	});
  32.  
  33. });

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

实现功能

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

  1. add_action('wp_ajax_cloadmore', 'comments_loadmore_handler'); // wp_ajax_{action}
  2. add_action('wp_ajax_nopriv_cloadmore', 'comments_loadmore_handler'); // wp_ajax_nopriv_{action}
  3.  
  4. function comments_loadmore_handler(){
  5.  
  6. 	global $post;
  7. 	$post = get_post( $_POST['post_id'] );
  8. 	setup_postdata( $post );
  9.  
  10. 	wp_list_comments( array(
  11. 		'avatar_size' => 100,
  12. 		'page' => $_POST['cpage'], 
  13. 		'per_page' => get_option('comments_per_page'),
  14. 		'style' => 'ol', 
  15. 		'short_ping' => true,
  16. 		'reply_text' => '回复',
  17. 	) );
  18. 	die;
  19. }

好了,今天的纯代码实现 ajax 评论无限加载 WordPress 教程就到此结束了,你是否成功实现效果了呢?有不懂的可以在下方评论。

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

已有 299 人购买
查看演示升级 VIP立刻购买

收藏
(0)

发表回复

热销模板

Ashade - 作品展示摄影相册WordPress汉化主题
LensNews

本站承接 WordPress / PbootCMS / DedeCMS 等
系统建站、仿站、开发、定制等业务!