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交流群。
文章来自小白学习资源站https://btzy.cc转载请保留本链接,谢谢!
声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。源码素材属于虚拟商品,具有可复制性,可传播性,一旦授予,不接受任何形式的退款、换货要求。请您在购买获取之前确认好 是您所需要的资源
1.本站提供的一切源码、教程和内容信息仅限用于学习和研究目的;不得将上述内容用于商业或者非法用途!
2.本站信息来自网络收集整理,版权争议与本站无关。您必须在下载后的24个小时之内,从您的电脑或手机中彻底删除上述内容!
3.本站提供的源码,模板,插件等其他资源都不包含技术服务,敬请谅解!
4.本站资源售价只是赞助,收取费用仅维持本站日常运营所需!
5.如无备注,本站不保证所提供下载的资源准确性安全性和完整性,源码仅供下载学习之用!
6.如用于商业或者非法用途,与本站无关。一切后果请自行负责!
7.如果遇到加密压缩包,默认解压密码为:btzy.cc或bori99.com如遇到无法解压请联系站长!