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

固定ページのURLの拡張子をhtmlに変更する

説明

固定ページについて、URLを静的ページっぽく拡張子htmlに変更したいという要望を受けることがある。これまでは「.html on PAGES」というプラグインを使っていて特に不満があったわけではないのだが、今回ひょんなことから簡単に対応できることがわかったので、メモ書きしておく。

きっかけとなったのは、カスタム投稿タイプのパーマリンク設定について調べている際にwp-includes/rewrite.phpをナナメ読みしている中、$wp_rewriteのget_page_permastructメソッドを見つけたあたり。さっそく自テーマのfunctions.phpにinitアクションを追加し、試したところあっけなく動作しました。コードは次の通り('mytheme'の部分はお好みで変更を)。

add_action( 'init', 'mytheme_init' );
if ( ! function_exists( 'mytheme_init' ) ) {
	function mytheme_init() {
		global $wp_rewrite;
		$wp_rewrite->use_trailing_slashes = false;
		$wp_rewrite->page_structure = $wp_rewrite->root . '%pagename%.html';
//		flush_rewrite_rules( false );
	}
}

ポイントは flush_rewrite_rules関数の呼び出し。これは1度だけ呼び出せばいいので、ここではコメント化している。また、管理ページの「設定」-「パーマリンク設定」にアクセスして、そのまま「変更を保存」ボタンを押すことで同様の効果があるので、どちらかの対応を選んでほしい。

なお、ここでは単に拡張子をhtmlにしているだけだが、例えばaboutのようなディレクトリ以下のページのようにすることも可能である。

$wp_rewrite->page_structure = $wp_rewrite->root . 'about/%pagename%.html';

スラッグが'about'の親ページ作っても対応できるのだが、こちらは応用例として紹介しておく。

追記)use_trailing_slashesプロパティの値がtrueの場合、URLの末尾に'/'が付与される場合がある。パーマリンク設定によってuse_trailing_slashesプロパティの値がfalseになる場合があるが、常に'/'をつけたくない場合は意図的にfalseを設定すること。


最終更新 : 2013年03月09日 00:22


お勧め

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 = '' ] )
投稿情報の抜粋記事を取得する。