越少的使用插件,却能让使用者完全体验到主题的各项功能,才是真正好的主题,这也是所有主题设计者应考虑的问题,本站目前的新主题基本实现了零插件。网上不使用插件实现WordPress功能的文章也很多,之前我也写过WordPress相关日志函数一文,今天再补一个不使用插件实现翻页功能的函数代码。
WordPress默认翻页功能很弱,一页页翻,弄到你手麻,所以类似wp-pagenavi翻页插件,几乎是WordPress博客必装的插件,也是普及率很高的一款插件。虽然网上有如何把wp-pagenavi插件集成到WordPress主题的教程,但wp-pagenavi插件函数代码拖沓,只是变相启用插件而已,并没有真正脱离wp-pagenavi插件。下面一段轻量级的函数,加上寥寥数行css样式就可以完全替代分页插件了。
具体实现方法:
首先将下面一段函数代码添加到主题的functions.php模板文件中:
- function kriesi_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 kriesi_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;
- }
上面的样式是我目前用的主题样式,根据不同的主题修改一下边框与背景,基本就可以了,之后删除分页插件。














很好的教程呢,谢谢分享的。
主题真漂亮。
请问版主 THEME 中的 Quarx 首页的大幻灯片如何添加自定义代码 我的老显示不出来 添加Image
主题站上说明没看懂?主题包中有添加缩略图的说明,英文如果和我一样差,看图片说明就够了,另外如果你用的空间是WIN主机,就放弃使用这款主题吧
为什么添加后, 上一页下一页 最后 最前 是乱码啊。
是编码错误,中文模版为UTF-8,无BOM
这个能够在自定义模板中使用吗?我试了下,页数和链接都能出现,但是点击上一页和下一页时页面没有变化,并没有跳转到相应的页面去。。。。这是怎么回事呢
请问博主:
接下来用下面的代码替换原来模板中默认翻页代码或分页插件代码:
这段代码在哪个文件里啊?
一般在archive.php index.php文件中,
比如WP默认模板是:
< ?php next_posts_link(__('« Older Entries', 'kubrick')) ?>
< ?php previous_posts_link(__('Newer Entries »', 'kubrick')) ?>
谢谢 找到了 我的代码是
汗 原来我输入不了代码
这方法不错,一会去折腾下
$range = 2; 我改成5之后,在category分类里面,选择最后一页,是没有内容的,甚至选择倒数的几页,也是空白的哦。。请问怎么修改呢? 谢谢
额 原来是判定的数值问题哦。因为我在archive.php下面是8篇,在后台阅读的是6篇。可上门的函数只调用后台默认的。
用得很好。。谢谢。。
这样做会不会拖慢速度?刚从引擎上点你的文章一直显示 在加载中
对我用的主题来说,没有加载任何多余的东西,所以不会影响速度
如果单日志实现分页..怎么弄呢..请教一下..
又是同一个问题,编辑文章时切换到代码模式,在分页处加{!--nextpage--} ,把{}换成<>
额.大哥..那如果我没采用你的方法..还是用插件.能不能插入nextpage标签?我试了好像不行..有没其他办法?
没听说日志分页还有插件,主题不支持分页插入标签也没用
插件是越少越好啊!
wp折腾去掉plugin,其乐无穷
我用这个主题做了个博客,为何没有分页呢?
我的函数是function pagination($query_string)
在index.php这个文件中的调用是:
为何没有效果呢?
这个如果在单独的页面加入貌似不显示分页
尝试了好几次都没用
很好的方法呢,先收藏了
收藏
这个要放在哪里吖?
用了下 效果很好
这个刚好看过,百度又进来啦,看样子不用百度了,直接在鸟哥站里搜就的了
博主好,最近更新了你的HotNews pro2.5主题,貌似2.5的主题已经集成了这篇文章里的分页代码,但是代码显示的效果不是很好,只能显示前几页的页码(1~7),超过7的页码都要点击“下一页”才能看到,而且最大页码也不显示再首页上,看着不是很舒服。
之前使用2.4没有这个问题,那是我还是用得wp-pagenavi分页导航插件,但是更新2.5后插件启用没反应,而且我发现你的博客分页导航和这篇文章的代码不一样啊,想问一下现在怎么在2.5的主题里去掉你这个翻页的效果还原成原来的?上面说替换的代码没有找到额。。。
现在我把“$range = 20; // 修改数字,可以显示更多的分页链”改成了20页现在可以显示全部页数了,但是翻页插件还是用不了,求帮助~~~
if(emptyempty($paged))$paged = 1; 博主的这行代码,貌似只要一个empty的函数吧
代码不错,拿来用了。。不过第5行写错了。。。
if(emptyempty($paged))$paged = 1;
应该是
if(empty($paged))$paged = 1;
请教个问题。 我弄的分页点击页码以后上面的URL看到的是已经转过去了。 但是页面的内容还是第一页的。 也就是说始终显示第一页的内容? 这个怎么解决? 望指教。
用你的这个代码页是一样。
请问代码添加在style。css的哪个位置啊?我是超级菜鸟啊!
加到最后
呵呵,感谢的五体投地,以后在CSS,我都知道加到最后了啊
直接复制代码,前面怎么还带着123456789等数字呢
换用其它非IE核心浏览器复制
呵呵,确实是这样的!
1.function kriesi_pagination($query_string){
这段代码放在FUNCTION.PHP的哪个位置啊?原谅我是超级菜鸟啊
加到functions中最后一个“?>”上面
感谢鸟哥仔细的解答,搞定了!
老大我的按照您的方法加上了
但是翻页好像不能用
只能实现翻页一次
第二次就无法翻页了,一直停留在第一次翻页后的页面
求解答啊
或者方法发到我邮箱
在此表示感谢了……
鸟哥,能不能实现 分页标题 呀! 这样对优化好点呀!
这个方法很不错
鸟哥,我的代码是这样该替换哪里啊?
max_num_pages;
if ( $total_pages > 1 ) {
echo '';
posts_nav_link(' | ', __('« Previous page','zbench'), __('Next page »','zbench'));
echo '';
}
}
?>