WordPressのページネーションといいますと『WP-PageNavi』と『 WP-Paginate』が代表的だと思います。しかし、プラグインを設置してしまうと、プラグインによっては不要なCSSコードも読み込まれてしまうため表示速度に影響がでてしまうのでは?と考える人もいるようです。

そこで、WordPressでプラグインなしでページネーションを設置する方法をご紹介します。

WordPressでプラグインなしでページネーションを設置する

編集するファイルはfunction.php、index.php・archive.php・category.phpなどのページをまたぎそうなファイル、CSSがメインになります。

function.php
//ページネーションを追加
function pagination($pages = '', $range = 4)
{
     $showitems = ($range * 2)+1;

     global $paged;
     if(empty($paged)) $paged = 1;

     if($pages == '')
     {
         global $wp_query;
         $pages = $wp_query->max_num_pages;
         if(!$pages)
         {
             $pages = 1;
         }
     }

     if(1 != $pages)
     {
         echo "<div class="pagination clearfix"><span>Page ".$paged." of ".$pages."</span>";
         if($paged > 2 && $paged > $range+1 && $showitems < $pages) echo "<a href='".get_pagenum_link(1)."'>&laquo; First</a>";
         if($paged > 1 && $showitems < $pages) echo "<a href='".get_pagenum_link($paged - 1)."'>&lsaquo; Previous</a>";

         for ($i=1; $i <= $pages; $i++)
         {
             if (1 != $pages &&( !($i >= $paged+$range+1 || $i <= $paged-$range-1) || $pages <= $showitems ))
             {
                 echo ($paged == $i)? "<span class="current">".$i."</span>":"<a href='".get_pagenum_link($i)."' class="inactive">".$i."</a>";
             }
         }

         if ($paged < $pages && $showitems < $pages) echo "<a href="".get_pagenum_link($paged + 1)."">Next &rsaquo;</a>";
         if ($paged < $pages-1 &&  $paged+$range-1 < $pages && $showitems < $pages) echo "<a href='".get_pagenum_link($pages)."'>Last &raquo;</a>";
         echo "</div>n";
     }
}
archive.php・category.phpなど
<?php if (function_exists("pagination")) {
    pagination($additional_loop->max_num_pages);
} ?>
style.cssなど

.pagination {
clear:both;
padding:20px 0;
position:relative;
font-size:11px;
line-height:13px;
}

.pagination span, .pagination a {
display:block;
float:left;
margin: 2px 2px 2px 0;
padding:6px 9px 5px 9px;
text-decoration:none;
width:auto;
color:#fff;
background: #555;
}

.pagination a:hover{
color:#fff;
background: #3279BB;
}

.pagination .current{
padding:6px 9px 5px 9px;
background: #3279BB;
color:#fff;
}

なぜ、プラグインを利用しないのか

先にも記述しましたが、不要なコードも多くあるのでそれを極力カットするという意味でもこういう方法があるということです。

例えば『WP-PageNavi』のプラグインを解凍しますと

  • admin.php
  • core.php
  • pagenavi-css.css
  • readme.txt
  • test.php
  • uninstall.php
  • wp-pagenavi.php

の他に、「lang」「scb」というフォルダがあるのですが、実際に使用するとしたら、デザイン変更でCSSとコードを多少いじってwp-pagenavi.phpくらいです。また、改変したあとにバージョンアップしてしまうと、全て上書きされますので、またデザインのし直しです。

ちょっとめんどいですね。間違ってプラグインを更新してしまうと最悪です。モチベーションだだ下がりです。

まとめ・その他

いかがでしたでしょうか。

というか、このプラグインを利用しないページネーションの記事は多数存在しますので、今更感は強いですが、参考になれば幸いです。

コメントを残す

メールアドレスが公開されることはありません。 * が付いている欄は必須項目です