この記事は最後に更新してから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_default_editor(2011年6月21日 更新)

string wp_default_editor( )
デフォルトの投稿エディタタイプを取得する。

delete_user_meta(2019年6月7日 更新)

bool delete_user_meta( int $user_id, string $meta_key [ , mixed $meta_value = '' ] )
ユーザメタ情報(拡張情報)を削除する。

get_header(2018年5月27日 更新)

void get_header( [ string $name = null ] )
ヘッダパーツを記述したメインヘッダファイルheader.php(またはサブヘッダファイルheader-???.php)を読み込む。

add_action(2018年5月27日 更新)

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

delete_option(2019年4月24日 更新)

bool delete_option( string $option )
サイトオプションを削除する。