欢迎您光临92源码网,秉承服务宗旨,履行"站长"责任,销售只是起点,服务永无止境!

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

作者 : admin 本文共2257个字,预计阅读时间需要6分钟 发布时间: 2021-10-19 共203人阅读
注:未经许可的【搬运】和【账号共享】可能会被取消VIP【每个都会记录ip,多ip封禁账号】
本站所有资源来源于网络,分享目的仅供大家学习和交流!不得使用于非法商业用途,不得违反国家法律。否则后果自负! 本站提供的资源,都不包含技术服务请大家谅解!如有链接无法下载、失效或广告,请联系站长处理!

评论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. 本站所有资源来源于网络,分享目的仅供大家学习和交流! 2. 不得使用于非法商业用途,不得违反国家法律。否则后果自负! 3. 本站提供的资源,都不包含技术服务请大家谅解! 4. 如有链接无法下载、失效或广告,请联系站长处理!

再次声明:如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。


92源码网 » WordPress纯代码实现ajax评论无限加载教程

常见问题FAQ

本站下载资源解压密码是什么?
本站所有资源解压密码均为www.92luntan.com或者www.huziy.com
免费下载或者VIP会员专享资源能否直接商用?
本站所有资源版权均属于原作者所有,这里所提供资源均只能用于参考学习用,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担。更多说明请参考 VIP介绍。
Copyright © 2018-2022 92源码资源网 - All rights reserved 浙ICP备14006446号-2
开通VIP 享更多特权,建议使用QQ登录