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

スマートフォン向けの振り分けを自前で行う

説明

PC向けのサイトをスマートフォン対応する場合、WPtouchやktai styleに代表されるスマートフォン対応のテンプレート切り替えプラグインを使用するのが一般的。そういったプラグインはテンプレート切り替え以外の機能も備えており、そういった機能は必ずしも必要ではない。そんなわけで、ここでは超シンプルなスマートフォン向けのテンプレート切り替えを実現する方法を紹介する。

template_includeフィルターを活用

テンプレートの振り分けを自身でコントロールする方法としては、template_includeフィルターを利用するのが手っ取り早い。具体的には、テーマ内のfunctions.phpにて、 add_filter関数を利用する。
add_filter( 'template_include', 'mytheme_template_include' );

function mytheme_template_include( $template ) {
	if ( is_smart_phone() ) {
		$template_sp = str_replace( '.php', '-sp.php', $template );
		if ( file_exists( $template_sp ) )
			$template = $template_sp;
	}
	return $template;
}
このtemplate_includeフィルターはindex.phpやsingle.phpといったテンプレートファイルの振り分けを行う直前に実行されるフィルターで、フィルター関数(ここではmytheme_template_include関数)のパラメータ$templateには最終的にWordPressシステムが選択したテンプレートファイルのフルパス名が格納されてくる。is_smart_phone関数はユーザーエージェントからスマートフォン判定するローカル関数で(内容は後述)、スマートフォンの場合にテンプレートファイル名を'index.php'から'index-sp.php'のように変更している。 あとはPC向けテンプレートと同じように○○-sp.phpを準備すれば、ユーザーエージェントがスマートフォンの場合は○○-sp.phpのテンプレートファイルが切り替えられる。なお、該当する○○-sp.phpが存在しない場合は○○.phpになる。

スマートフォン判定

WordPressにはグローバル変数 $is_iphoneがあるが、Androidスマートフォンが対象にならないため、独自のスマートフォン判定を行うis_smart_phone関数を定義する。
function is_smart_phone() {
	return preg_match( '/android.+mobile/i', $_SERVER['HTTP_USER_AGENT'] ) ||
		preg_match( '/iphone/i', $_SERVER['HTTP_USER_AGENT'] );
}
ここではiPhoneとAndroidスマートフォンならtrueを、それ以外はfalseを返す。Windows PhoneやBlackBerryスマートフォンなどを含める場合は、適宜それらの条件を追加する必要がある。またAndroidスマートフォン・タブレットの一部にはイレギュラーが存在するため、それらも正しく振り分けたい場合は個別に対応しなければならない。 テーマのスマートフォン対応をコンパクトに実現する方法は、ざっとこんな感じになる。スマートフォン向け、タブレット向けなど、サイトの目的に応じて自由にテンプレートファイルを振り分けたい場合は、こういった方法を選択してもいいのではないだろうか。

最終更新 : 2012年01月23日 19:54


お勧め

get_userdata(2022年2月4日 更新)

mixed get_userdata( int $user_id )
ユーザIDを指定し、マッチするユーザ情報を取得する。

has_filter(2022年11月8日 更新)

mixed has_filter( $tag, [ mixed $function_to_check = false ] )
WordPressタグにフィルターが登録されているか調べる。

wp_add_object_terms(2013年8月6日 更新)

mixed wp_add_object_terms( int $object_id, mixed $terms, mixed $taxonomy )
投稿情報などにタクソノミーを追加する。

is_tag(2018年5月27日 更新)

bool is_tag( [ mixed $slug = '' ] )
要求されているページが、タグアーカイブページか調べる。

add_meta_box(2014年11月16日 更新)

void add_meta_box( string $id, string $title, string $callback, string $page [, string $context = 'advanced' [, string $priority = 'default' [, array $callback_args = null ] ] ] )
投稿ページに独自のメタボックスを表示する。