WordPress教程 2020年02月25日
0 收藏 0 点赞 1,057 浏览 1769 个字
摘要 :

评论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建站交流群:907326213

实现功能

最后我们在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.wpjc.net/971.html

相关推荐
测试
日期:2022-10-21 点赞:0 阅读:1,235
WordPress获取文章内第一张图片为缩略图
如果你的站点文章数量很多,那么每一篇文章都要手动设置缩略图必然会是个繁杂的步骤,之前我们分享过一篇《WordPress文章随机显示缩略图的实…
日期:2020-12-16 点赞:0 阅读:2,509
一行代码让你的网站变灰进入哀悼模式
深切哀悼在抗击新冠肺炎斗争中的牺牲烈士和逝世同胞, 愿逝者安息,愿生者奋发,愿祖国昌盛。 让我们一起接力,一起变灰,一起哀悼。 网站变灰的方…
日期:2020-12-16 点赞:0 阅读:1,974
WordPress添加网址加载时间
最近比格经常在别的博客上看到“页面加载时间n秒”的效果,然后群里也有人在问,所以比格今天就写一篇Wordpress添加网址加载时间的Word…
日期:2020-12-16 点赞:0 阅读:1,873
WordPress后台只显示当前用户的文章和媒体文件
在我们使用WordPress多用户主题的时候,WordPress后台会默认显示的所有用户文章、媒体文件,这样的情况会导致大家都可以看到其他用…
日期:2020-12-16 点赞:0 阅读:1,891
WordPress纯代码免插件配置SMTP邮件功能教程
SMTP邮件功能在WordPress中是很常用的功能, 例如:网站注册登录、评论回复等风,虽然WordPress自带了mail函数,但是使用…
日期:2020-12-16 点赞:0 阅读:2,478
发表评论
75 条评论

还没有评论呢,快来抢沙发~

助力内容变现

将您的收入提升到一个新的水平

点击联系客服

在线时间:8:00-16:00

客服电话

400-888-8888

客服邮箱

ceotheme@ceo.com

扫描二维码

关注微信公众号

扫描二维码

手机访问本站