AT互联|WordPress纯代码实现ajax评论无限加载教程_
AT互联|WordPress纯代码实现ajax评论无限加载教程_手机扫码预览

AT互联|WordPress纯代码实现ajax评论无限加载教程_

939
免费 优惠信息:免费 暂无永久SVIP下载特权
  • 免费售前咨询
  • 登录下载更划算哦
  • 付费安装资源
  • 付费终身升级
  • QQ保障售后服务
  • 网站应急咨询顾问

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

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

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

AT互联|WordPress纯代码实现ajax评论无限加载教程_-AT互联全栈开发服务商

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

AT互联|WordPress纯代码实现ajax评论无限加载教程_-AT互联全栈开发服务商

添加“加载更多”按钮

首先在你在主题中查找评论分页功能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交流群。

文章来自AT互联https://www.at8848.cn转载请保留本链接,谢谢!

打破行业潜规则-更多选择 更低价格 更快交付!
AT互联全栈开发服务商 » AT互联|WordPress纯代码实现ajax评论无限加载教程_
欢迎您光顾,建议使用 QQ 登录
喜欢我嘛?喜欢就按“ctrl+D”收藏我吧!♡