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

固定ページを投稿ページ用テンプレートファイル(single.php)で表示する

説明

固定ページと投稿ページのデザインが共通の場合、同じ内容のsingle.phpとpage.phpを用意すれば事足りるが、デザインの修正時は二度手間になってしまう。そこで、固定ページをsingle.phpで表示するようにできないか考えてみた。

テンプレートファイルは、リクエストURLに応じて投稿情報を取得したあと、/wp-includes/template-loader.phpにて投稿情報の状態に応じて適切なテンプレートファイルを読み込む仕組みになっている。リクエストURLが固定ページ、すなわち is_page関数の戻り値がtrueの場合は、get_page_template関数にてテーマ内のpage.phpなどの固定ページ用テンプレートファイルが存在するか調べ、存在する場合は読み込みを、存在しない場合は別のテンプレートファイルを探すようになっている(ほとんどのテーマでは、index.phpになる)。

get_page_template関数をトレースしていくと、page_templateフィルターが実行されていることがわかったので、このフィルターを使うことで固定ページをsingle.phpで表示するようにしてみた。具体的に自テーマのfunctions.phpに追加するコードは次の通り(「mytheme_」の部分は適宜置き換えて使用していただきたい)。

function mytheme_singular_template( $template ) {
	if ( $template == '' )
		$template = locate_template( array( 'single.php' ) );
	return $template;
}
add_filter( 'page_template', 'mytheme_singular_template' );

このフィルター関数が呼び出されるタイミングは、テーマ内の固定ページ用テンプレートファイルの検索後である。テーマに固定ページ用テンプレートファイルがなかった場合は、パラメータ$templateの値は''となるので、その場合にのみ locate_template関数を使ってsingle.phpを探し、その結果を返すようにしている。このようにすることで、後でpage.phpが用意された場合はそれが適用されるし、仮にsingle.phpが見つからなかった場合は最終的にindex.phpが適用されるようになる。

こんなレアケースに遭遇した場合はお試しください。


最終更新 : 2013年07月31日 18:17


お勧め

get_the_date(2018年5月27日 更新)

mixed get_the_date ( [ string $d = '' [ , mixed $post = null ] ] )
パラメータ$dで指定したフォーマットで投稿日を取得する。

is_php_version_compatible(2019年5月10日 更新)

bool is_php_version_compatible( string $required )
PHPバージョンの互換性を調べる。

in_category(2018年5月27日 更新)

bool in_category( mixed $category [ , mixed $post = null ] )
投稿情報が指定したカテゴリーに属しているか調べる。

get_category(2018年5月27日 更新)

mixed get_category( mixed $category [ , string $output = OBJECT [ , string $filter = 'raw' ] ] )
IDを指定してカテゴリー情報を取得する。

add_action(2018年5月27日 更新)

bool add_action( string $tag, mixed $function_to_add [ , int $priority = 10 [ , int $accepted_args = 1 ] ] )
WordPressシステムの関数にアクション関数を追加する。