WordPress如何通过代码实现无限加载

分类栏目:案例分享

129

评论是一个活跃、拉近站长和用户的一个区域。把握好评论区的热度对网站优化,用户直接感受网站是一个可以交流的平台。

而看评论会发现只会展现几条消息,看更多评论只能点击下一页,这在用户体验度上不是很好。如果把点击下一页改为AJAX无限加载,体验感会好很多。
下面分享如何通过代码实现这一功能

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

一、添加“加载更多”按钮

首先在你在主题中查找评论分页功能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文件并插入下面的代码。

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到页面,这里就不详细说了,不懂得朋友可以直接咨询我。

三、在Wordpress中应用

在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;
}

 
 即可