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

    WordPress纯代码实现ajax评论无限加载教程 最后编辑:2020-10-21
    增值服务: 自动发货 使用说明 安装指导 环境配置二次开发BUG修复

    评论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交流群。

    文章来自大资源网https://www.dzy10.com转载请保留本链接,谢谢!

    猜你在找

    • 2020-06-07Hi,初次和大家见面了,请多关照!

    售后服务:

    • 售后服务范围 1、商业模板使用范围内问题免费咨询
      2、源码安装、模板安装(一般 ¥50-300)服务答疑仅限SVIP用户
      3、单价超过200元的模板免费一次安装,需提供服务器信息。
      付费增值服务 1、提供dedecms模板、WordPress主题、discuz模板优化等服务请详询在线客服
      2、承接 WordPress、DedeCMS、Discuz 等系统建站、仿站、开发、定制等服务
      3、服务器环境配置(一般 ¥50-300)
      4、网站中毒处理(需额外付费,500元/次/质保三个月)
      售后服务时间 周一至周日(法定节假日除外) 9:00-23:00
      免责声明 本站所提供的模板(主题/插件)等资源仅供学习交流,若使用商业用途,请购买正版授权,否则产生的一切后果将由下载用户自行承担,有部分资源为网上收集或仿制而来,若模板侵犯了您的合法权益,请来信通知我们(Email: 3482249445@qq.com),我们会及时删除,给您带来的不便,我们深表歉意!

    Hi, 如果你对这款模板有疑问,可以跟我联系哦!

    联系作者
    升级SVIP尊享更多特权立即升级
    My title page contents
    召唤伊斯特瓦尔