在制作WordPress主題模板時(shí),我們會(huì)用到循環(huán)輸出文章列表,文章列表太多就會(huì)有分頁(yè)的問(wèn)題,下面是一種分頁(yè)方法,十分好用,可以設(shè)定頁(yè)數(shù)范圍。
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('上一頁(yè)');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>";
}
}
echo "<li>";next_posts_link('下一頁(yè)');echo"</li>";
echo '<li><span>共'.$max_page.'頁(yè)</span></li>';
}
}
將上面的代碼放在WordPress主題文件目錄下的functions.php中,然后在你需要的地方使用下面的代碼調(diào)用:
<?php get_pagenavi();?>
本文不提供相關(guān)css代碼,可根據(jù)自己的需求添加css代碼。
新主題官方微信公眾號(hào)
掃碼關(guān)注新主題(XinTheme)官方公眾號(hào),本站動(dòng)態(tài)早知道。
發(fā)布本站最新動(dòng)態(tài)(新主題發(fā)布、主題更新)和WordPress相關(guān)技術(shù)文章。