wordpressでプラグインを使わないでページ送りを設置

電脳備忘録

本記事のソースコードの利用によって生じた損害について、当方は一切の責任を負いません。ご自身の判断と責任のもとで参照・ご利用ください。

この記事は最終更新から3年以上経過しています。

更新しました

2016.12.22に更新しました。

wordpressは基本的にプラグインを突っ込んでカスタマイズするものだと勝手に解釈しています。
そんな中「サイトにページ送りをつけてほしい。ただしプラグインはなしな」と言われてしまい困ってしまいました。しかし探せばあるものですね。非常に助かりました。

WordPressでは多くのページネーションを実装するプラグインがありますが、使用しているテーマにあったデザインで機能も必要なものだけにできるように、プラグイン無しでページネーションを設置する方法を紹介します。

WordPressにプラグイン無しでページネーションを設置する方法

functions.phpに下記のコードを貼り付けました。今回使わないタグの削除やcssの設定等、若干手を入れています。

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=\"pagenavi\">";
         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 page\">".$i."</span>":"<a href='".get_pagenum_link($i)."' class=\"page larger\">".$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";
     }
}

呼び出すテンプレートに書く

<?php if (function_exists("pagination")) {
    pagination($additional_loop->max_num_pages);
} ?>

更新

function.phpに記載

//ページ送り
function pagination($pages = '', $range = 2) {
  $showitems = ($range * 2)+1;//表示するページ数(5ページを表示)
  global $paged;//現在のページ値
  if(empty($paged)) $paged = 1;//デフォルトのページ
  if($pages == '') {
    global $wp_query;
     $pages = $wp_query->max_num_pages;//全ページ数を取得
     if(!$pages) {
     	$pages = 1;//全ページ数が空の場合は、1とする
     }
  }
  if(1 != $pages) {
		//全ページが1でない場合はページネーションを表示する
		echo "<div id=\"pagenation\">\n";
		echo "<ul>\n";
		//Prev:現在のページ値が1より大きい場合は表示
    if($paged > 1) echo "<li class=\"prev\"><a href='".get_pagenum_link($paged - 1)."'>前へ</a></li>\n";
    	for ($i=1; $i <= $pages; $i++) {
      if (1 != $pages &&( !($i >= $paged+$range+1 || $i <= $paged-$range-1) || $pages <= $showitems )) {
      	//三項演算子での条件分岐
        echo ($paged == $i)? "<li class=\"active\">".$i."</li>\n":"<li><a href='".get_pagenum_link($i)."'>".$i."</a></li>\n";
      }
    }
		//Next:総ページ数より現在のページ値が小さい場合は表示
		if ($paged < $pages) echo "<li class=\"next\"><a href=\"".get_pagenum_link($paged + 1)."\">次へ</a></li>\n";
		echo "</ul>\n";
		echo "</div><!-- /ページ送り -->\n";
  }
}

ページ送りさせていテンプレートに記載

if (function_exists("pagination")) {
		pagination($additional_loop->max_num_pages);
	}
0%