标题 | 非插件实现wp博客具体页码分页导航 |
内容 | 在很多wordpress主题中,分页导航都是采用传统的“上一页”“下一页”两个链接,但这种方法并不实用,我们希望把他变成“1 2 3 ...”具体的页码。有一个实现方法是使用wp-pagenavi插件,但这么一个小小的功能,我们希望把它整合进主题中,以减少对插件的依赖。 具体的实现方法是: 1.首先在主题functions.php中加入以下代码: /* pagenavi */ function pagenavi( $before = '', $after = '', $p = 2 ) { if ( is_singular() ) return; global $wp_query, $paged; $max_page = $wp_query->max_num_pages; if ( $max_page == 1 ) return; if ( empty( $paged ) ) $paged = 1; echo $before.'<div id=pagenavi>'.n; echo '<span class=pages>page: ' . $paged . ' of ' . $max_page . ' </span>'; if ( $paged > 1 ) p_link( $paged - 1, 'previous page', '«' ); if ( $paged > $p + 1 ) p_link( 1, 'first page' ); if ( $paged > $p + 2 ) echo '... '; for( $i = $paged - $p; $i <= $paged + $p; $i++ ) { if ( $i > 0 && $i <= $max_page ) $i == $paged ? print <span class='page-numbers current'>{$i}</span> : p_link( $i ); } if ( $paged < $max_page - $p - 1 ) echo '... '; if ( $paged < $max_page - $p ) p_link( $max_page, 'last page' ); if ( $paged < $max_page ) p_link( $paged + 1,'next page', '»' ); echo '</div>'.$after.n; } function p_link( $i, $title = '', $linktype = '' ) { if ( $title == '' ) $title = page {$i}; if ( $linktype == '' ) { $linktext = $i; } else { $linktext = $linktype; } echo <a class='page-numbers' href=', esc_html( get_pagenum_link( $i ) ), ' title='{$title}'>{$linktext}</a>; } 2.然后在页面相应位置,把原来的分页导航代码改成以下: <?php pagenavi(); ?> 这样就已经实现了分页导航,但此时的分页导航还很难看,页码都挤在一起,所以我们需要在style.css中进行适当装饰: /* pagenavi */ #pagenavi a, #pagenavi a:visited, #pagenavi span { height: 25px; line-height: 25px; display: inline-block; padding: 1px 8px; } #pagenavi a, #pagenavi a:visited { margin: 0 2px; } #pagenavi span.pages { color: #777; font-weight: bold; margin-right: 10px; padding: 0; } #pagenavi span.current { margin: -2px 2px -1px; padding: 0 9px; height: 28px; line-height: 28px; text-align: center; } 当然,这里只是简单的装饰,你可以根据主题风格做必要的修改。 |
随便看 |
|
在线学习网考试资料包含高考、自考、专升本考试、人事考试、公务员考试、大学生村官考试、特岗教师招聘考试、事业单位招聘考试、企业人才招聘、银行招聘、教师招聘、农村信用社招聘、各类资格证书考试等各类考试资料。