WordPress纯代码实现ajax评论无限加载教程
评论AJAX加载方式的优点在于用户体验,不用点击翻译,但是个人觉得一般站点的评论也没有多少,更不说需要翻页的。…
评论AJAX加载方式的优点在于用户体验,不用点击翻译,但是个人觉得一般站点的评论也没有多少,更不说需要翻页的。
所以博主没有采用评论无限加载,但是或许有人喜欢那?
所以今天就分享一篇实现ajax评论无限加载的WordPress教程,最终效果如下图所示:
在使用AJAX加载评论时,需要在后台设置-评论设置,进行如下的设置(其中每页显示评论数量可以根据你的需要自定义)。
添加“加载更多”按钮
首先在你在主题中查找评论分页功能paginate_comments_links()函数,并将其替换为以下代码。若找不到此函数,请在代码…后面放置代码
1 2 3 4 5 6 7 8 9 10 |
$cpage = get_query_var(‘cpage’) ? get_query_var(‘cpage’) : 1; |
由于默认显示最后的评论页面,$cpage所以等于注释页面的最大数量。条件if( $cpage > 1 ) {意味着两件事情同时发生 – 在下列情况下输出加载更多按钮和脚本。
无限加载 jQ
首先我们创建一个ajax-comment.js文件并复制下面的代码到js文件中。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 |
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到页面,这里就不详细说了.
实现功能
最后我们在functions.php中插入下面代码 :
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 |
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( |
好了,今天的纯代码实现ajax评论无限加载WordPress教程就到此结束了,你是否成功实现效果了呢?有不懂的可以在下方评论.
本文收集自互联网,转载请注明来源。
如有侵权,请联系 wper_net@163.com 删除。
还没有任何评论,赶紧来占个楼吧!