owned mediaウェブ制作に役立つコンテンツを発信中!

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でコンテンツを公開するときに、デザインの一部に番号を使うような場面にはピッタリだと思いますので、ぜひ試してみてください。  
  • はてなブックマーク
  • Pocket
  • Linkedin
  • Feedly

この記事を書いた人

Twitter

sponserd

    keyword search

    recent posts

    • Twitter
    • Github
    contact usscroll to top
      • Facebook
      • Twitter
      • Github
      • Instagram