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

固定ページを投稿ページ用テンプレートファイル(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が適用されるようになる。

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

関連

  • add_filter - フィルター関数を追加する
  • is_page - ページか調べる
  • locate_template - テンプレートファイルが存在するか確認する

お勧めコンテンツ

plugin_basename(2011年10月5日 登録)

string plugin_basename( string $file )
プラグインのベース名(プラグインディレクトリ以下の部分)を取得する。

add_plugins_page(2011年5月31日 登録)

mixed add_plugins_page( string $page_title, string $menu_title, mixed string $capability, string $menu_slug [ , mixed $function = '' ] )
プラグインメニューにサブメニューを登録する。

image_constrain_size_for_editor(2011年12月1日 登録)

array image_constrain_size_for_editor( int $width, int $height [ , mixed $size = 'medium' ] )
イメージの縮小サイズを取得する。

remove_submenu_page(2011年5月27日 登録)

mixed remove_submenu_page( string $menu_slug, string $submenu_slug )
サブメニューを削除する。

get_the_archive_description(2014年12月23日 登録)

string get_the_archive_description()
アーカイブページの説明を取得する。

最終更新日時 : 2013-07-31 18:17