我们在制作 WordPress 主题模板时,经常会用到循环输出文章列表,但是文章列表太多就会有分页的问题,我们知道 wordpress 默认的只有前一页后一页,没有数字分页的功能,使用这种 WordPress 默认分页访客体验很不友好,下面是一种分页方法,十分好用,今天就分享纯代码实现的一点小小经验给大家。
function get_pagenavi( $range = 4 ) {
global $paged,$wp_query;
if ( !$max_page ) {
$max_page = $wp_query->max_num_pages;
}
if( $max_page >1 ) {
if( !$paged ){
$paged = 1;
}
echo "<li>"; previous_posts_link('上一页');echo"</li>";
if ( $max_page >$range ) {
if( $paged <$range ) {
for( $i = 1; $i <= ($range +1); $i++ ) {
echo "<li><a href='".get_pagenum_link($i) ."'";
if($i==$paged) echo " class='current'";echo ">$i</a></li>";
}
}elseif($paged >= ($max_page -ceil(($range/2)))){
for($i = $max_page -$range;$i <= $max_page;$i++){
echo "<li><a href='".get_pagenum_link($i) ."'";
if($i==$paged)echo " class='current'";echo ">$i</a></li>";
}
}elseif($paged >= $range &&$paged <($max_page -ceil(($range/2)))){
for($i = ($paged -ceil($range/2));$i <= ($paged +ceil(($range/2)));$i++){
echo "<li><a href='".get_pagenum_link($i) ."'";if($i==$paged) echo " class='current'";echo ">$i</a></li>";
}
}
}else{
for($i = 1;$i <= $max_page;$i++){
echo "<li><a href='".get_pagenum_link($i) ."'";
if($i==$paged)echo " class='current'";echo ">$i</a></li>";
将上面的代码放在主题目录下的 function.php 中,在你需要的地方使用下面的代码调用:
<div class="pagination">
<ul>
<?php get_pagenavi();?>
</ul>
</div>
专业提供WordPress主题安装、深度汉化、加速优化等各类网站建设服务,详询在线客服!