当前位置:   article > 正文

wordpress框架自定义添加page分页功能_wordpress页面视频太多,如何设置分页

wordpress页面视频太多,如何设置分页

先来看效果图:

一、在主题目录下的functions.php文件里,添加如下分页函数: 

  1. /**
  2. * 数字分页函数
  3. * 说明:因为wordpress默认仅仅提供简单分页,所以要实现数字分页,需要自定义函数
  4. * @Param bool $isHome 是否为主页
  5. * @Param int $range 数字分页的宽度
  6. * @Return string|empty 输出分页的HTML代码
  7. */
  8. function number_pagenavi($isHome,$range = 4) {
  9. global $paged,$wp_query;
  10. /*如果是首页,则自定义查询*/
  11. if($isHome){
  12. $number = $wp_query->post_count;
  13. //只统计手游、端游、页游三个分类
  14. $query = new WP_Query(array(
  15. 'category_name' => 'shouyou,duanyou,yeyou',
  16. ));
  17. $total = $query->found_posts;//总条数
  18. $max_page = ceil($total/$number);//总页码
  19. }else{
  20. $total = $wp_query->found_posts;//总条数
  21. if ( !$max_page ) {
  22. $max_page = $wp_query->max_num_pages;//总页码
  23. }
  24. }
  25. if ( !$max_page ) {
  26. $max_page = $wp_query->max_num_pages;
  27. }
  28. if( $max_page >1 ) {
  29. echo "<div class='fenye'>";
  30. if( !$paged ){
  31. $paged = 1;
  32. }
  33. if( $paged != 1 ) {
  34. echo "<a href='".get_pagenum_link(1) ."' class='extend' title='跳转到首页'>首页</a>";
  35. }else{
  36. echo "<a class='extend' style='color:#ccc;'>首页</a>";
  37. }
  38. previous_posts_link('上一页');
  39. if ( $max_page >$range ) {
  40. if( $paged <$range ) {
  41. for( $i = 1; $i <= ($range +1); $i++ ) {
  42. echo "<a href='".get_pagenum_link($i) ."'";
  43. if($i==$paged) echo " class='current'";echo ">$i</a>";
  44. }
  45. }elseif($paged >= ($max_page -ceil(($range/2)))){
  46. for($i = $max_page -$range;$i <= $max_page;$i++){
  47. echo "<a href='".get_pagenum_link($i) ."'";
  48. if($i==$paged)echo " class='current'";echo ">$i</a>";
  49. }
  50. }elseif($paged >= $range &&$paged <($max_page -ceil(($range/2)))){
  51. for($i = ($paged -ceil($range/2));$i <= ($paged +ceil(($range/2)));$i++){
  52. echo "<a href='".get_pagenum_link($i) ."'";if($i==$paged) echo " class='current'";echo ">$i</a>";
  53. }
  54. }
  55. }else{
  56. for($i = 1;$i <= $max_page;$i++){
  57. echo "<a href='".get_pagenum_link($i) ."'";
  58. if($i==$paged)echo " class='current'";echo ">$i</a>";
  59. }
  60. }
  61. next_posts_link('下一页');
  62. if($paged != $max_page){
  63. echo "<a href='".get_pagenum_link($max_page) ."' class='extend' title='跳转到最后一页'>尾页</a>";
  64. }else{
  65. echo "<a class='extend' disabled='disabled' style='color:#ccc;' >尾页</a>";
  66. }
  67. echo '<span style="margin-left:10px;">共'.$max_page.'页</span>';
  68. echo "</div>\n";
  69. }
  70. }

我这个函数是按网站需求做了一些调整和修改,因为我首页只显示三个分类,直接用$wp_query->max_num_pages查总页码的话是不准的,所以你要根据自己的网站数据来调整这个函数的代码。

二、在公共的css文件里添加样式,代码如下:

  1. /*------------------
  2. 分页部分的CSS
  3. ------------------*/
  4. .fenye{
  5. text-align: center;
  6. height: 25px;
  7. line-height: 25px;
  8. _background: #F9F9F9;
  9. padding: 2px 5px;
  10. margin: 20px 4px;
  11. _border: solid 1px #ccc;
  12. _text-align: center;
  13. }
  14. .fenye a{
  15. padding:4px 6px 4px 6px;
  16. margin:0 2px 0 2px;
  17. border:1px solid #aaa;
  18. text-decoration:none;
  19. color:#333;
  20. cursor: pointer;
  21. }
  22. .fenye a.current{
  23. background:#ff6f3d;
  24. color:#fff;
  25. }
  26. .fenye a:hover{
  27. background:#ff6f3d;
  28. color:#fff;
  29. }
  30. /*-- footer --*/
  31. .footer {
  32. width:100%;
  33. height:64px;
  34. background:#E6E9ED;
  35. border-top: 1px solid #e2e2e3;
  36. }
  37. /*-- post --*/
  38. .post {
  39. background:none;
  40. }
  41. .post .entry-cnt {
  42. height:auto;
  43. line-height:2;
  44. font-size:14px;
  45. border-top-width: 1px;
  46. border-top-style: dotted;
  47. border-top-color: #eee;
  48. padding:15px 0 0;
  49. }
  50. .post .entry-cnt p {
  51. line-height:2;
  52. font-size:14px;
  53. }
  54. .related {
  55. padding:10px 5px 10px 5px;
  56. border-top:1px solid #eee;
  57. border-bottom:1px solid #eee;
  58. margin: 20px auto 10px auto;
  59. }
  60. .r-left {
  61. float:left;
  62. }
  63. .r-right {
  64. float:right;
  65. }
  66. /*-- discuss --*/
  67. .discuss {
  68. padding:25px;
  69. }

三、在需要使用分页的位置,插入以下代码:

  1. <!-- 插入分页功能 -->
  2. <?php number_pagenavi(false); ?>

本文内容由网友自发贡献,转载请注明出处:https://www.wpsshop.cn/w/Monodyee/article/detail/242233
推荐阅读
相关标签
  

闽ICP备14008679号