由于WordPress系统的差异性,很多时候我们能不使用插件就别使用插件。如何在不使用插件的情况下实现文章分页的效果?
网上不使用插件实现Wordpress功能的文章也很多,今天再补一个不使用插件实现翻页功能的函数代码。
WordPress默认翻页功能很弱,一页页翻,弄到你手麻,所以类似wp-pagenavi翻页插件,几乎是WordPress博客必装的插件,也是普及率很高的一款插件。
虽然网上有如何把wp-pagenavi插件集成到WordPress主题的教程,但wp-pagenavi插件函数代码拖沓,只是变相启用插件而已,并没有真正脱离wp-pagenavi插件。下面一段轻量级的函数,加上寥寥数行css样式就可以完全替代分页插件了。
具体实现方法:
首先将下面一段函数代码添加到主题的functions.php模板文件中:
//分页功能
function pagination($query_string){
global $posts_per_page, $paged;
$my_query = new WP_Query($query_string .\"&posts_per_page=-1\");
$total_posts = $my_query->post_count;
if(empty($paged))$paged = 1;
$prev = $paged - 1;
$next = $paged + 1;
$range = 2; // only edit this if you want to show more page-links
$showitems = ($range * 2)+1;
$pages = ceil($total_posts/$posts_per_page);
if(1 != $pages){
echo \"<div class=\'pagination\'>\";
echo ($paged > 2 && $paged+$range+1 > $pages && $showitems < $pages)? \"<a href=\'\".get_pagenum_link(1).\"\'>最前</a>\":\"\";
echo ($paged > 1 && $showitems < $pages)? \"<a href=\'\".get_pagenum_link($prev).\"\'>上一页</a>\":\"\";
for ($i=1; $i <= $pages; $i++){
if (1 != $pages &&( !($i >= $paged+$range+1 || $i <= $paged-$range-1) || $pages <= $showitems )){
echo ($paged == $i)? \"<span class=\'current\'>\".$i.\"</span>\":\"<a href=\'\".get_pagenum_link($i).\"\' class=\'inactive\' >\".$i.\"</a>\";
}
}
echo ($paged < $pages && $showitems < $pages) ? \"<a href=\'\".get_pagenum_link($next).\"\'>下一页</a>\" :\"\";
echo ($paged < $pages-1 && $paged+$range-1 < $pages && $showitems < $pages) ? \"<a href=\'\".get_pagenum_link($pages).\"\'>最后</a>\":\"\";
echo \"</div>n\";
}
}
接下来用下面的代码替换原来模板中默认翻页代码或分页插件代码:
<?php pagination($query_string); ?>
最后再把下面的样式代码添加到style.css中,刷新一下页面,与使用插件实现的翻页效果一样。
.pagination{
line-height:23px;
}
.pagination span, .pagination a{
font-size:12px;
margin: 2px 6px 2px 0;
background:#fff;
border:1px solid #e5e5e5;
color:#787878;
padding:2px 5px 2px 5px;
text-decoration:none;
}
.pagination a:hover{
background: #8391A7;
border:1px solid #fff;
color:#fff;
}
.pagination .current{
background: #fff;
border:1px solid #8d8d8d;
color:#393939;
font-size:12px;
padding:2px 5px 2px 5px;
}
上面的样式是我目前用的主题样式,根据不同的主题修改一下边框与背景,基本就可以了,之后删除分页插件。
© 版权声明
1. 资源都是经过站长或作者收集测试修改后发布分享。如若转载请在文内以超链形式注明狐狸库文章出处,谢谢合作!
2. 本站除原创内容,其余所有内容均收集自互联网,仅限用于学习和研究目的,本站不对其内容的合法性承担任何责任。如有版权内容,请通知我们或作者删除,其版权均归原作者所有,本站虽力求保存原有版权信息,但因众多资源经多次转载,已无法确定其真实来源,或已将原有信息丢失,所以敬请原作者谅解!
3. 本站用户所发布的一切资源内容不代表本站立场,并不代表本站赞同其观点和对其真实性负责,若您对本站所载资源作品版权归属存有异议,请留言附说明联系邮箱,我们将在第一时间予以处理 ,同时向您表示歉意!为尊重作者版权,请购买原版作品,支持您喜欢的作者,谢谢!
4. 本站一律禁止以任何方式发布或转载任何违法的相关信息,访客如有发现请立即向站长举报;本站资源文件大多存储在云盘,如发现链接或图片失效,请联系作者或站长及时更新。
THE END
请登录后查看评论内容