• 注册
  • 个人说明:TA有点懒了,什么都没有写。
    关注 1 粉丝 0 喜欢 0 内容 256
    河南省·郑州市
    聊天 送礼

    新版界面开发进度

    14%
    其实就是啥也没写,只有想法,哈哈
    • 回帖总排行
    • 采纳总排行

    分享精彩给好友

    全部文章 关注:0 内容:1074

    WordPress分页代码实现WordPress文章列表分页【转】

  • 查看作者
  • 打赏作者
  • 拉黑名单
    • WordPress集成了自动分页功能,使用WordPress分页代码调用WordPress分页方法,就可以快速为WordPress文章列表分页,这个方法在WordPress仿站制作WordPress主题时非常有用。

      WordPress自带的分页函数非常难看,不能看到页码,只能看到上一页下一页首页,用户体验极差。像大前端DUX主题这种带页码的分页方法就非常不错,不仅显示总共有多少页,而且还自动省略多余的页码,用户体验极佳,效果如本站的文章列表分页。

      WordPress分页代码实现WordPress文章列表分页

      这种WordPress文章列表分页方法不仅可以随时回到首页,还会自动省略中间的页码,只显示用户所在位置附近的页码,还有上一页下一页以及总共多少页,可以说是把用户需要的条件都考虑进去了。

      WordPress分页代码

      function mo_paging() {
          $p = 3;
          if ( is_singular() ) return;
          global $wp_query, $paged;
          $max_page = $wp_query->max_num_pages;
          if ( $max_page == 1 ) return; 
          echo '<div class="pagination"><ul>';
          if ( empty( $paged ) ) $paged = 1;
          echo '<li class="prev-page">'; previous_posts_link('上一页'); echo '</li>';
          if ( $paged > $p + 1 ) _paging_link( 1, '<li>第一页</li>' );
          if ( $paged > $p + 2 ) echo "<li><span>···</span></li>";
          for( $i = $paged - $p; $i <= $paged + $p; $i++ ) { 
              if ( $i > 0 && $i <= $max_page ) $i == $paged ? print "<li class=\"active\"><span>{$i}</span></li>" : _paging_link( $i );
          }
          if ( $paged < $max_page - $p - 1 ) echo "<li><span> ... </span></li>";
          echo '<li class="next-page">'; next_posts_link('下一页'); echo '</li>';
          echo '<li><span>共 '.$max_page.' 页</span></li>';
          echo '</ul></div>';
      }
      
      function _paging_link( $i, $title = '' ) {
          if ( $title == '' ) $title = "第 {$i} 页";
          echo "<li><a href='", esc_html( get_pagenum_link( $i ) ), "'>{$i}</a></li>";
      }

      将上面的代码放入主题目录下的functions.php文件中,在文章列表循环结束后调用mo_paging()方法即可显示WordPress分页效果。需要注意的是这段代码只是输出了HTML标签,并没有css,大家需要自己写上自己喜欢的css样式代码。

      你需要登录,才能进行发帖操作