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

评论 加载方式的优点在于用户体验,不用点击翻译,但是个人觉得一般站点的评论也没有多少,更不说需要翻页的。 所以博主没有采用评论无限加载,但是或许有人喜欢那? 所以今天就分享一篇实现 评论无限加载的 教程,最终效果如下图所示: 在使用 加载评论时,需要在后台设置 评论设置,进行如下的设置(其中每页显示评论数量可以根据你的需要自定义)。 添加 加载更多 按钮 首先在你在主题中查找评论分页功能 函数,并将其替换为以下代码。若找不到此函数,请在代码 后面放置代码 由于默认显示最后的评论页面, 所以等于注释页面的最

应用介绍

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

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

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

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

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

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

添加“加载更多”按钮

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

$cpage = get_query_var(\'cpage\') ? get_query_var(\'cpage\') : 1;
 
if( $cpage > 1 ) {
 echo \'
More comments
[removed] var ajaxurl = \\\'\' . site_url(\'wp-admin/admin-ajax.php\') . \'\\\', parent_post_id = \' . get_the_ID() . \', cpage = \' . $cpage . \' [removed]\'; }

由于默认显示最后的评论页面,$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到页面,这里就不详细说了,不懂得朋友可以加入我们的WordPress交流群交流:

WordPress建站交流群:8424781

实现功能

最后我们在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;
}

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

有价值(0) 没价值(0)

立即下载

评论列表 共有 0 条评论

暂无评论
立即
投稿
发表
评论
返回
顶部