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

サイドバーの初期化はwidgets_initアクションで

説明

ウィジェットを使ってみたくなり新テーマ「Twenty Eleven」を覗いてみると、codexに記載されていた内容と少し違っている。これって「Twenty Ten」ですでに変更されていたんだね。 ウィジェットを利用することでサイドバーの表示内容を簡単に変更できる。codexによると、テーマのfunctions.phpにて register_sidebar関数を使用する方法が紹介されている。
<?php
if ( function_exists( 'register_sidebar' ) )
	register_sidebar();
?>
これはregister_sidebar関数が定義されているかを調べ、関数が定義されているならサイドバーを登録するというもの。register_sidebar関数が使用できる2.2.0より前のバージョンで誤動作しないようになっている。
これに対し「Twenty Eleven」では、 add_action関数を使い、widgets_initアクションで twentyeleven_widgets_init関数を呼び出し、ウィジェットやサイドバーの登録を行っている。自テーマにて単にサイドバーを登録するだけなら、functions.phpに次のように記述する。
<?php
add_action( 'widgets_init', 'mytheme_widgets_init' );

function mytheme_widgets_init() {
	register_sidebar();
}
?>
ここでは関数名をmytheme_widgets_initとしているが、関数名はユニークであればいい(テーマ内の命名ルールに準じて適切な名前を付けること)。
さて「Twenty Eleven」のtwentyeleven_widgets_init関数では、独自のウィジェットを登録した後で5つのサイドバーを登録している。独自のウィジェットも実際に作ってみないとね。

最終更新 : 2011年07月14日 15:18


お勧め

wp_validate_redirect(2016年4月22日 更新)

string wp_validate_redirect( string $locaution [ , string $default = '' ] )
URLがリダイレクト先として有効か調べる。

wp_make_link_relative(2018年5月27日 更新)

mixed wp_make_link_relative( mixed $link )
URLからフルパス名を取得する。

get_month_link(2012年2月2日 更新)

string get_month_link( mixed $year, mixed $month )
月アーカイブのURLを取得する。

_n(2019年2月22日 更新)

string _n( string $single, string $plural, int $number [ , string $domain = 'default' ] )
数値フォーマットの翻訳テキストを取得する。

get_post_types(2017年3月6日 更新)

array get_post_types( [ array $args = array() [ , string $output = 'names' [ , string $operator = 'and' ] ] ] )
投稿タイプ情報を列挙する。