WordPress纯代码实现提交评论ajax翻页效果

WordPress提交评论ajax翻页的效果会很大的提高用户体验度,虽然我们一般的个人WordPress博客评论也不会有很多,但是用户体验至上嘛,所以主题君今天分享一篇WordPress实现提交评论ajax翻页效果的WordPress教程,希望能给大家能用得上。

最终效果如下图所示:

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

添加“加载更多”按钮

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


1
2
3
4
5
6
7
8
9
10
$cpage = get_query_var('cpage') ? get_query_var('cpage') : 1;
 
if( $cpage > 1 ) {
    echo '&lt;div class="comment_loadmore">More comments&lt;/div>
    &lt;script>
    var ajaxurl = \'' . site_url('wp-admin/admin-ajax.php') . '\',
        parent_post_id = ' . get_the_ID() . ',
            cpage = ' . $cpage . '
    &lt;/script>';
}

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

无限加载 jQuery代码


1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
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 中插入下面代码:


1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
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&#91;'post_id'] );
    setup_postdata( $post );
 
    wp_list_comments( array(
        'avatar_size' => 100,
        'page' => $_POST&#91;'cpage'],
        'per_page' => get_option('comments_per_page'),
        'style' => 'ol',
        'short_ping' => true,
        'reply_text' => '回复',
    ) );
    die;
}

至此,WordPress纯代码实现提交评论ajax翻页效果的教程就结束了,看到这里你应该也已经知道如何实现这个功能了。

扫码关注wp主题君

精选优质免费WordPress主题模板,分享最新WordPress实用建站教程!

记住我们的网址:ztJun.com

未经允许不得转载:主题君 » WordPress纯代码实现提交评论ajax翻页效果
赞(184)

评论抢沙发

评论前必须登录!

账号密码登录