SQL_CALC_FOUND_ROWS查询主要是解决文章计数,进而进行分页处理,列表页查询耗时主要在这个上面
有没有更好的解决办法呢?
答案:有的!
以下分页方法查询会更快
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 | 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>"; } } echo "<li>";next_posts_link('下一页');echo"</li>"; echo '<li><span>共'.$max_page.'页</span></li>'; } } |
然后在需要分页的地方使用以下代码调用
1 | <?php get_pagenavi();?> |
分页的ul li标签的css请自行定义,上述只给出了php方法
原文链接:https://xiaohost.com/10435.html,转载请注明出处。
评论0