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

2021-03-08 0 104

教程wordpress错误_WordPress如何在文章列表编辑特色图像

谈论AJAX加载方式的优点在于用户体验不用点击翻译然则小我私人以为一样平时站点的谈论也没有若干更不说需要翻页的。

以是博主没有接纳谈论无限加载然则或许有人喜欢那?

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

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

在使用AJAX加载谈论时需要在后台设置-谈论设置举行如下的设置(其中每页显示谈论数目可以凭证你的需要自定义)。

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

添加“加载更多”按钮

首先在你在主题中查找谈论分页功效paginate_comments_links()函数并将其替换为以下代码。若找不到此函数请在代码< ol class=\"comment-list\">...< /ol >后面放置代码

Wordpres多站点设置(站群建设)详细方式_wordpress建站教程

$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;
	});

});

实现功效

最后我们在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;
}

收藏 (0) 打赏

感谢您的支持,我会继续努力的!

打开微信/支付宝扫一扫,即可进行扫码打赏哦,分享从这里开始,精彩与您同在
点赞 (0)

一直被模仿,从未被超越!

常见问题
  • 本站所有源码都是通过互联网采集而来,不保证源码得完整性和可用性,如果介意请勿购买!
查看详情
  • 本站源码不提供任何服务帮助。本站只是提供源码,不提供服务帮助!
查看详情

相关文章

官方客服团队

为您解决烦忧 - 24小时在线 专业服务