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

https://www.wpon.cn/

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

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

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

2d097e16e2adf64e524b05f55f879086.gif

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

dbbb8e273b68d54b39b043be8963398a.png

添加“加载更多”按钮

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

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

if( $cpage > 1 ) {

echo '

More comments

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

parent_post_id = ' . get_the_ID() . ',

cpage = ' . $cpage . '

';

}

由于默认显示最后的评论页面,$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;

}

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值