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

文章来自苏果儿博客https://cdn.suguoer.com转载请保留本链接,谢谢!

发表评论

登录... 后才能评论

发现网站内无您想要的资源或者素材,可以联系站长或者提交工单:提交工单
支持下载网站: 千图网 觅知网 模板客 搬码网 阿奇源码 诛仙资源网
点击上方链接了解下载规则介绍。

本站所有资源版权均属于原作者所有,这里所提供资源均只能用于参考学习用,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担。更多说明请参考 VIP介绍。

最常见的情况是下载不完整: 可对比下载完压缩包的与网盘上的容量,若小于网盘提示的容量则是这个原因。这是浏览器下载的bug,建议用百度网盘软件或迅雷下载。 若排除这种情况,可在对应资源底部留言,或联络我们。

对于会员专享、整站源码、程序插件、网站模板、网页模版等类型的素材,文章内用于介绍的图片通常并不包含在对应可供下载素材包内。这些相关商业图片需另外购买,且本站不负责(也没有办法)找到出处。 同样地一些字体文件也是这种情况,但部分素材会在素材包内有一份字体下载链接清单。

如果您已经成功付款但是网站没有弹出成功提示,请联系站长提供付款信息为您处理

源码素材属于虚拟商品,具有可复制性,可传播性,一旦授予,不接受任何形式的退款、换货要求。请您在购买获取之前确认好 是您所需要的资源

如果您在下载中遇到资源失效或者无法下载,请复制连接发给站长,站长会在24内补齐缺失的资源下载连接。