WordPressで投稿記事にインデックス番号を付ける
最終更新日: Update!!
先日、クライアントワークのWordPress案件で、投稿順に番号を付けるという要件があり、その時に実装した内容をメモしておきたいと思います。WordPressにはデフォルトで投稿記事のインデックス番号を取得できる情報は単体で無いようなので、自前で実装する必要があります。今回は下記のコードで作成してみました。
【PHP】※一部抜粋
<ul> <?php if(have_posts()): ?> <?php while(have_posts()): the_post(); ?> <li> この投稿は<?php $paged = get_query_var( 'paged' ); $perPage = get_query_var( 'posts_per_page' ); $paged === 0 ? $paged = 1 : $paged = get_query_var( 'paged' ); $count = $wp_query->current_post + 1; echo ( $paged - 1 ) * $perPage + $count; ?>番目です </li> <?php endwhile; ?> <?php endif; ?> </ul>投稿順の番号を正しく振り当てるために、今回は下記のような投稿の情報が必要となります。これらの情報がないと、ページ送りした際に番号が変わってしまいます。 ・get_query_var( 'paged' ) で現在のページ目次を取得 ・get_query_var( 'posts_per_page' ) でページあたりの表示件数を取得 ・$wp_query->current_post でページ内に表示されている投稿の順序を取得 注意したいのは「current_post」はページごとにインデックス番号が振られるため、現在のページ数とページあたりの表示件数を掛け合わせた数字を足すことがポイントになります。上記のコードが下記のようなHTMLで表示される形になります。 また、過去記事「WordPressでmax_num_pagesとget_query_varを使ってページネーションを実装する」でも紹介していますが、現在のページ数は1ページ目の場合には0で返されるので、先頭ページの場合には条件分岐で1が代入されるようにしておきます。 【HTML】※一部抜粋
<ul> <li>この投稿は1番目です</li> <li>この投稿は2番目です</li> <li>この投稿は3番目です</li> <li>この投稿は4番目です</li> ...... </ul>これで、投稿順にインデックス番号をあてることができました。WordPressでコンテンツを公開するときに、デザインの一部に番号を使うような場面にはピッタリだと思いますので、ぜひ試してみてください。
sponserd
keyword search
recent posts
- Shopifyでオリジナルテーマ制作やテーマカスタマイズで使えるTips #3
Shopifyでオリジナルテーマ制作やテーマカスタマイズで使えるTips #3
- Shopifyでオリジナルテーマ制作やテーマカスタマイズで使えるTips #2
Shopifyでオリジナルテーマ制作やテーマカスタマイズで使えるTips #2
- Shopifyでオリジナルテーマ制作やテーマカスタマイズで使えるTips #1
Shopifyでオリジナルテーマ制作やテーマカスタマイズで使えるTips #1
- ViteでReactとReact Routerを使ってみる
ViteでReactとReact Routerを使ってみる
- ViteでPugのコンパイル環境を導入する
ViteでPugのコンパイル環境を導入する
- ViteでMarkuplintとPrettierを使える環境を構築する
ViteでMarkuplintとPrettierを使える環境を構築する
- ViteでStylelintとESlintを使える環境を構築する
ViteでStylelintとESlintを使える環境を構築する
- マウスオーバーしたセルを含む行列がハイライトするテーブルを作成する:has()擬似クラスの活用例
マウスオーバーしたセルを含む行列がハイライトするテーブルを作成する:has()擬似クラスの活用例
categories