WordPress纯代码实现ajax评论无限加载教程
评论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. 如有链接无法下载、失效或广告,请联系站长处理!
再次声明:如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。
HI模板网 » WordPress纯代码实现ajax评论无限加载教程
常见问题FAQ
- 本站下载资源解压密码是什么?
- 本站所有资源解压密码均为www.hmoban.com、www.huziy.com或者www.92luntan.com
- 免费下载或者VIP会员专享资源能否直接商用?
- 本站所有资源版权均属于原作者所有,这里所提供资源均只能用于参考学习用,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担。更多说明请参考 VIP介绍。