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

4.4では投稿ページも専用テンプレートが適用できる

説明

従来、特定の固定ページには専用テンプレートを適用できるのですが、投稿ページに適用させるためにはアクションやフィルターを利用する必要がありました。4.4では特定の投稿ページに標準で専用テンプレートを適用できるようになりそうです。

beta2、beta3がさくさく公開され、ソースコードを追い切れていないわけです。そんな中でふと見つけたのが、今回紹介する内容です。

適切なテンプレートファイルを用意してテンプレート内の振り分け処理を無くす」で紹介しているようにWordPressのテーマではさまざまなテンプレートが利用できます。これまでのテーマでは、「page-{スラッグ(投稿名)}.php」や「page-{投稿ID}.php」という名前でテンプレートを用意しておけば特定の固定ページに専用のテンプレートを適用できましたが、これはあくまでも固定ページのみ。投稿ページで同じようなことを実現するためには、template_redirectアクションやtemplate_includeフィルターなどを利用する必要がありました。

4.4では、投稿ページ向けのテンプレートの適用順が変更されています。

優先度テンプレートファイル名
single-{投稿タイプ名}-{スラッグ(投稿名)}.php [4.4.0]
single-{投稿タイプ名}.php
single.php

たとえば標準の投稿ページで、スラッグが'hello'の場合、single-post-helllo.phpというファイル名のテンプレートを用意しておけばいいわけです。固定ページのように投稿IDでの指定はできないのですが、この機能を利用すれば、特定の投稿ページのみ異なるデザインを適用させるのが容易になります。ちょっとしたことかもしれませんが、実用性は高い変更点ではないでしょうか。


最終更新 : 2018年05月27日 10:45


お勧め

get_the_post_thumbnail_caption(2018年5月27日 更新)

string get_the_post_thumbnail_caption( mixed $post = null )
投稿ページのサムネイル(アイキャッチ画像)キャプションを取得する。

wp_enqueue_style(2019年11月25日 更新)

void wp_enqueue_style( string $handle [ , string $src = false [ , array $deps = array() [ , string $ver = false [ , string $media = 'all' ] ] ] ] )
使用するスタイルシート(CSS)を出力用のキューに入れる。パラメータ$srcが指定された場合は、グローバル変数$wp_stylesに登録してから出力用のキューに入れる。

post_class(2018年5月27日 更新)

void post_class( [ string $class = '' [ , int $post_id = null ] ] )
投稿情報の種別に応じたクラス属性(class="post-?? post ...")を表示する。具体的なクラス名は、投稿ID(post-番号)、投稿種別(postやpage)、カテゴリー(category-名前)、タグ(tag-名前)などがある。これらクラス名に合わせたCSSを準備することで、投稿ページのユニークなデザインが表現可能になる。

get_header(2020年8月18日 更新)

void | false get_header( [ string $name = null [ , array $args = array() ] ] )
ヘッダパーツを記述したメインヘッダファイルheader.php(またはサブヘッダファイルheader-???.php)を読み込む。

get_the_excerpt(2018年5月27日 更新)

string get_the_excerpt( [ mixed $post = null$deprecated = '' ] )
投稿情報の抜粋記事を取得する。