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

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

后面放置代码

1
2
3
4
5
6
7
8
9
10
$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文件并复制下面的代码到js文件中。

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[‘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教程就到此结束了,你是否成功实现效果了呢?有不懂的可以在下方评论.

温馨提示:本文最后更新于 2023-12-09 15:46 ,某些文章具有时效性,若有错误或已失效,请在下方留言或联系QQ115904045
声明:
1.本站大部分内容均收集于网络!若内容若侵犯到您的权益,请发送邮件至:115904045@qq.com,我们将第一时间处理!
2.资源所需价格并非资源售卖价格,是收集、整理、编辑详情以及本站运营的适当补贴,并且本站不提供任何免费技术支持
3.所有资源仅限于参考和学习,版权归原作者所有,更多请阅读网站声明

给TA打赏
共{{data.count}}人
人已打赏
wordpress教程

WordPressphp升级到7.4提示Warning:UseofundefinedconstantGMT–assumed‘GMT’

2023-12-9 15:46:36

wordpress教程

站群建设-Wordpres多站点配置方法

2023-12-9 15:46:39

  • 0 条回复 A文章作者 M管理员
      暂无讨论,说说你的看法吧
    购物车
    优惠劵
    今日签到
    有新私信 私信列表
    搜索

    夕阳无别事,等风也等你

    联系我们