概要
widget_title
フィルタは、WordPressのウィジェットのタイトルをカスタマイズするために使用されるフックです。このフィルタを使用することで、ウィジェットのタイトルを動的に変更したり、装飾を加えたりすることができます。特に、WooCommerceプラグインと連携して使用されることが多く、以下のような機能を実装する際に役立ちます。
- ウィジェットタイトルの自動翻訳
- 特定の条件に基づくウィジェットタイトルの表示制御
- CSSクラスを追加してタイトルのスタイルを変更
- ユーザーのロールに基づくタイトルの変更
- 日時に基づくタイトルの動的変更
- テーマに応じた独自のタイトル出力
このフィルタを使用できるWooCommerceのバージョンは通常のバージョンに依存しますが、基本的にはWooCommerce 2.0以上、WordPressは4.0以上が必要です。
構文
function custom_widget_title( $title, $instance, $id_base ) {
return $title;
}
add_filter( 'widget_title', 'custom_widget_title', 10, 3 );
パラメータ
$title
: ウィジェットの元のタイトル$instance
: ウィジェットインスタンス設定$id_base
: ウィジェットのIDベース
戻り値
カスタマイズされたウィジェットタイトル(文字列)。
この関数のアクションでの使用可能性
アクション | 使用可能性 |
---|---|
mu_plugin_loaded | |
registered_post_type | |
plugins_loaded | |
wp_roles_init | |
setup_theme | |
after_setup_theme | |
set_current_user | |
init | |
register_sidebar | 〇 |
wp_loaded | |
send_headers | |
parse_query | |
pre_get_posts | |
wp | |
template_redirect | |
get_header | |
wp_head |
サンプルコード
サンプル1: ウィジェットタイトルにプレフィックスを追加
このコードは、すべてのウィジェットタイトルの前に「カスタム:」というプレフィックスを追加します。
function add_prefix_to_widget_title( $title ) {
return 'カスタム: ' . $title;
}
add_filter( 'widget_title', 'add_prefix_to_widget_title' );
サンプル2: 特定のウィジェットタイトルを変更
特定のウィジェットのタイトルを変更する例です。このコードは「最近の投稿」ウィジェットタイトルを「新着記事」に変更します。
function change_recent_posts_widget_title( $title, $instance ) {
if ( 'recent-posts' === $instance['widget_id'] ) {
return '新着記事';
}
return $title;
}
add_filter( 'widget_title', 'change_recent_posts_widget_title', 10, 2 );
サンプル3: 日付に応じたタイトルの変更
このサンプルでは、特定の日付以降はウィジェットタイトルを変更します。
function modify_widget_title_based_on_date( $title ) {
if ( strtotime( '2023-01-01' ) < time() ) {
return '2023年以降の特別タイトル';
}
return $title;
}
add_filter( 'widget_title', 'modify_widget_title_based_on_date' );
サンプル4: ウィジェットのタイトルにカウントを追加
このコードは、ウィジェットのタイトルにアイテム数を追加します。
function add_item_count_to_widget_title( $title, $instance ) {
if ( ! empty( $instance['items_count'] ) ) {
return $title . ' (' . intval( $instance['items_count'] ) . '件)';
}
return $title;
}
add_filter( 'widget_title', 'add_item_count_to_widget_title', 10, 2 );
サンプル5: ロールに基づくタイトルの条件付き変更
このコードでは、特定のユーザーロールに基づいてウィジェットタイトルを変更します。
function change_title_based_on_user_role( $title ) {
if ( current_user_can( 'administrator' ) ) {
return '管理者向けタイトル';
}
return $title;
}
add_filter( 'widget_title', 'change_title_based_on_user_role' );
各サンプルコードは、著作権フリーのアイデアに基づいており、具体的な引用元はありませんが、WordPress Codexや公式ドキュメントを参考にしています。