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

  • 文章介绍
  • 评价建议
  • 温馨提示:
    本站为源代码分享站,源码多为网友投稿 我们没有对源码进行测试,不保证可用性、安全性以及版权归属。 因源码具有可复制性,一经购买 ,不得以任何形式退款。
    如需商业用途 请点击商业源码栏目,购买商业源码.
    客服QQ:977439673

    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到页面,这里就不详细说了

    实现功能

    最后我们在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交流群。

    发表评论

  • 如本资源侵犯了您的权益,[email protected]!我们将在收到邮件的1个小时内处理完毕。

  • 本站仅为平台,发布的资源均为用户投稿或转载!所有资源仅供参考学习使用,请在下载后的24小时内删除,禁止商用!

  • OKMG(芒果源码)助力正版,如您有自己的原创产品,可以联系客服投稿,代理出售!

  • OKMG(芒果源码)客服QQ:29139260

  • OKMG(芒果源码)商务电话(仅对企业客户/个人用户请联系QQ客服):010-86463891

  • 请注意:本站不提供任何免费的技术咨询服务,为了节约时间,下载前 请确认自己会技术
  • 免责声明 芒果源码,一个精品商业网站源码分享平台 WWW.OKMG.CN 1. 本站所有资源来源于用户上传和网络,均不允许转载,如有侵权请邮件联系站长! 2. 分享目的仅供大家学习和交流,您必须在下载后24小时内删除! 3. 如发现会员转载本站资源文章,本站有权封禁会员账号! 4. 不得使用于非法商业用途,不得违反国家法律。否则后果自负! 5. 本站提供的源码、模板、插件等等其他资源,都不包含技术服务请大家谅解! 6. 如有链接无法下载、失效或广告,请联系管理员处理! 7. 本站资源售价只是赞助,收取费用仅维持本站的日常运营所需! 8. 如遇到加密压缩包,默认解压密码为"www.okmg.cn",如遇到无法解压的请联系管理员! 9.本站客服:29139260

    售后服务:

    • 售后服务范围 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: [email protected]),我们会及时删除,给您带来的不便,我们深表歉意!

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

    联系客服
    开通VIP 享更多特权,建议使用 QQ 登录
    /** * 项目名称:用户离开标题切换 */