最新公告
  • 欢迎您光临站库网,本站秉承服务宗旨 履行“站长”责任,销售只是起点 服务永无止境!立即加入我们
  • WordPress纯代码实现ajax评论无限加载教程

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

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

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

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

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

    WordPress纯代码实现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文件并复制下面的代码到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交流群。

    1. 本站所有资源来源于用户上传和网络,因此不包含技术服务请大家谅解!如有侵权请邮件联系客服!zhanku@aliyun.com
    2. 本站不保证所提供下载的资源的准确性、安全性和完整性,资源仅供下载学习之用!如有链接无法下载、失效或广告,请联系客服处理,有奖励!
    3. 您必须在下载后的24个小时之内,从您的电脑中彻底删除上述内容资源!如用于商业或者非法用途,与本站无关,一切后果请用户自负!
    4. 如果您也有好的资源或教程,您可以投稿发布,成功分享后有站币奖励和额外收入!
    站库网 » WordPress纯代码实现ajax评论无限加载教程

    发表评论

    你的前景,远超我们想象

    选择学么=选择高薪,选择=成功

    • 原创课程

      课程独家原创

    • 零基础

      人人都能轻松入门

    • 注重实战

      轻理论重实战讲实效

    • 高品质

      一对一在线答疑

    • 用心服务

      解除后顾之忧

    • 手机学习

      随时随地轻松学习