WordPressのページネーションをプラグイン未使用で実装する方法
MENU
  1. HOME
  2. WordPress / カスタマイズ
  3. WordPressのページネーションをプラグイン未使用で実装する方法

最近の作業実績

  • 2022年10月18日不要になっていたコンテンツをサイト内から除去いたしました。
  • 2022年10月17日サイト内の画像が表示されない不具合を修正いたしました。
  • 2022年10月16日サイト内で発生した大量の404エラーを修正いたしました。
  • 2022年10月15日既存サイトの各所を簡単に更新できる機能を追加いたしました。
  • 2022年10月14日過去記事を定期的に自動ツイートする機能をテーマに実装いたしました。
  • 2022年10月13日サイト内の広告を一括管理できる機能をテーマに実装いたしました。
  • 2022年10月12日既存サイトのトップページを再構築いたしました。
  • 2022年10月11日クラシックエディターで管理されていたコンテンツをブロックエディターで再構築いたしました。
  • 2022年10月10日複数のサイトの更新情報を一括表示させる機能をテーマに実装いたしました。
  • 2022年10月09日WordPressの管理画面にオリジナルの管理ページを実装いたしました。
  • 2022年10月08日コンタクトフォーム7で構築されたフォームに確認画面とサンクスページを導入いたしました。
  • 2022年10月07日既存サイトのサーバー移管を担当いたしました。
  • 2022年10月06日フッターのレイアウトを再設計いたしました。
  • 2022年10月05日既存サイトのカラーを一括管理できる機能をテーマに実装いたしました。
  • 2022年10月04日新規ページを5ページ作成いたしました(デザイン込み)。
  • 2022年10月03日訪問者に閲覧履歴を表示する機能をテーマに実装いたしました。
  • 2022年10月02日ログインできなくなったWordPressを復旧いたしました。
  • 2022年10月01日オリジナルテーマの制作を担当いたしました。
  • 2022年09月30日破損していたテーマを修正いたしました。
  • 2022年09月29日アフィリエイト審査用のサイト立ち上げを担当いたしました。
  • このエリアには直近の制作実績を一部掲載しております。
  • 制作実績はリアルタイム反映ではありません。

WordPressのページネーションをプラグイン未使用で実装する方法

この投稿は2019/05/05に加筆修正いたしました。

WordPressサイトにプラグインを使わずページネーションを実装するコードをご紹介します。プラグインを使わずにページネーションを設置したい方は参考にしてください。1分でページネーションを設置できます。

この記事は約 7 分で読めます。

今回は、プラグインを使わず、ページネーションを実装する方法をご紹介します。

ページネーションとは、記事数が増えて記事一覧が複数ページに分割されたとき、ページ間の移動を行うためのリンクのことです。

上記はページネーションの一例です。

とある案件で、このページネーションを実装することになりました。

WordPressで構築したサイトにページネーションを設置しようとすると、ほとんどの方がプラグインの【WP-PageNavi】などに行き着くかと思います。

プラグインを使っても構わないのですが、個人的にプラグインの数は減らしたほうが良いと言う考え方なので、私の構築するサイトではプラグインを使わずにページネーションを設置しています。

プラグインを使わずにページネーションをsエッチする方法を、以下にご紹介します。

WordPressにページネーションを実装する手順

今回ご紹介するページネーションは、このサイトでも実際に利用しているものです。

これからご紹介するコードをコピペすれば、このサイトと同じページネーションを実装することができますので、試してみてください。

ページネーションを実装する手順は以下のとおりです。

  • ページネーションを表示させるコードをテーマに追加する
  • CSSでページネーションを装飾する

個別に見ていきましょう。

手順1:ページネーションを表示させるコードをテーマに追加する

まずは、ページネーションを表示させたい箇所に、以下のコードを記述してください。

<div id="pagination">
<?php global $wp_rewrite;
$paginate_base = get_pagenum_link(1);
if (strpos($paginate_base, '?') || ! $wp_rewrite->using_permalinks()) {
$paginate_format = '';
$paginate_base = add_query_arg('paged', '%#%');
} else {
$paginate_format = (substr($paginate_base, -1 ,1) == '/' ? '' : '/') .
user_trailingslashit('page/%#%/', 'paged');;
$paginate_base .= '%_%';
}
echo paginate_links( array(
'base' => $paginate_base,
'format' => $paginate_format,
'total' => $wp_query->max_num_pages,
'mid_size' => 5,
'current' => ($paged ? $paged : 1),
)); ?>
</div>

上記のコードをどこに設置してよいのかは、お使いのテーマによって異なります。

基本的に、記事一覧ページを定義しているファイル(例:loop.php)の、記事一覧を表示させているコードを直下辺りに設置するのが良いかと思います。

上記のコードを記述させた箇所に、以下のようなページネーションが表示されます。

上記の画像は、後述するCSSを適応した場合の見た目です。
現段階では、上記のような見た目になっていなくても大丈夫です。
CSSで装飾する方法は、次の項を参照してください。

記事数が少なく、記事一覧が複数ページに分割されていない場合は、上記のコードを設置してもページネーションは表示されません。

記事数が増えて記事一覧ページが複数に分割されれば、ページネーションが表示されるようになります。

ページネーション部分のHTMLは以下のようになっています。

<div id="pagination">
<span aria-current='page' class='page-numbers current'>1</span>
<a class='page-numbers' href='https://takayakondo.com/blog/page/2/'>2</a>
<a class='page-numbers' href='https://takayakondo.com/blog/page/3/'>3</a>
<a class='page-numbers' href='https://takayakondo.com/blog/page/4/'>4</a>
<span class="page-numbers dots">…</span>
<a class='page-numbers' href='https://takayakondo.com/blog/page/20/'>20</a>
<a class="next page-numbers" href="https://takayakondo.com/blog/page/2/">次へ »</a></div>

吐き出されるHTMLは、記事一覧ページのページ数などによって若干異なります。
上記は、このサイトのページネーションのHTMLです。

ここまでの作業で、ページネーション本体の設置は完了です。

手順2:CSSでページネーションを装飾する

続けて、ページネーションの見た目を、CSSで整えていきます。

ページネーションの見た目は、CSSで自由に装飾することができます。
CSSが書ける方は、先ほどのHTMLを参考に、好みの装飾を行ってください。

以下に記述するコードは、このサイトで実際に使用しているCSSコードです。

#pagination {
color: #2583ad;
margin: 30px auto;
line-height:2em;
}
a.page-numbers, #pagination .current {
color: #00019b;
padding: 10px;
border:solid 1px #ccc;
text-decoration:none;
font-size:smaller;
background:white;
}
a.page-numbers:hover {
color:white;
background: #328ab2;
}
#pagination .current {
color: white;
background: #328ab2;
border: #328ab2;
font-weight:bold;
}
.next,
.prev {
border:0 none;
background:transparent;
font-weight:bold;
}

上記のCSSを適応させると、以下のような見た目になります。

上記のCSSを調整して、ご自身の好みに合わせた装飾をするのが良いかと思います。

ページネーションが表示されない場合

上記で説明した手順に従ってもページネーションが表示されない場合、以下のいずれかに該当する可能性が高いです。

  • テーマの他の部分と競合(コンクリフト)している
  • 一部のプラグインと競合(コンクリフト)している
  • コードを記述する箇所が適切でない

ページネーションが表示されない理由は、サイトごとに異なります。
ご自身での対応が難しい場合は、当方で不具合の調査と修正を代行いたします

お気軽にご相談ください。

まとめ

WordPressのページネーションをプラグイン未使用で実装する方法をご紹介しました。

  • ページネーションを表示させるコードをテーマに追加する
  • CSSでページネーションを装飾する

たった2ステップでページネーションを設置できました。
コードもコピペだけでよいので、簡単ですね。

ページネーションはブログ形式のサイトには必須の機能です。
プラグインを使わないでも実装可能ですのでぜひ試してみてください。

Wordpressのカスタマイズや不具合など
何かお困りのことはありませんか?

Wordpressに関連するあなたのお悩み、解決いたします。
次のような方は、お気軽にご相談下さい。

  • Wordpressサイトをカスタマイズしたいが、やり方が分からないで困っている。カスタマイズの知識が豊富な人に任せたい。
  • Wordpressサイトに不具合が発生したが、直し方が分からない。不具合の修正経験が豊富な人に任せたい。
  • 既存サイトにWordPressを導入したいが、やり方が複雑で自分ではできそうにもない。経験が豊富な人に任せたい。
  • WordPressがハッキングされたが修正の仕方が分からない。サイトを元通りにできる人を探している。
  • Wordpressで0からサイトを制作したいが、自分ではできそうにもない。プロにサイト制作を委託したい。

一つでも該当する方は、以下のフォームからお気軽にご相談下さい。

WordPressに関して今すぐ相談する

著者:takaya kondo

岡山在住のWordPress専門フリーランサーです。Wordpressを使ったWEBサイト制作を中心に10年間ほど活動させていただいています。

Wordpress関連の記事でお役に立てれば幸いです。

【関連記事】あなたが興味のありそうな関連記事をご紹介します。

コメントを残す

(必須)

CAPTCHA