只今WordPressのテーマ制作の勉強をしておりますまっちーです!
WordPressでメニューにふりがなを付ける方法を書き留めておきたいと思います。
メニュー名の上に小さい文字で書かれているこういうやつですね。
data:image/s3,"s3://crabby-images/6b66a/6b66ac6ab8146b00cc324f41dab8e09b7248e998" alt=""
まずふりがなではなく、サブナビゲーションなどと言われるようです。
(どおりで検索しても全然ヒットしない)
それでは作っていきます!
functions.phpにコードを追記する
functions.phpに以下のコードを追記する
add_filter('walker_nav_menu_start_el', 'description_in_nav_menu', 10, 4);
function description_in_nav_menu($item_output, $item){
return preg_replace('/(<a.*?>[^<]*?)</', "<br /><span>{$item->attr_title}</span><br>$1<", $item_output);
}
参考:Offise Kondo【WordPress】カスタムメニューでサブタイトルつきのメニューを作成する方法
サブタイトルを入力するフォームを表示させる
管理画面→外観→メニュー→表示オプションをクリック
data:image/s3,"s3://crabby-images/d08ef/d08efe00954fd4fdad8fca0f1378e4ae2e3b0adc" alt=""
「タイトル属性」にチェックを入れる
data:image/s3,"s3://crabby-images/88b66/88b66221d75a250a2cc5b5d53b75d937f9d9cc79" alt=""
サブタイトルを入力する
メニューの項目に「タイトル属性」が表示されるのでこちらにサブタイトルを入力する
data:image/s3,"s3://crabby-images/a6db2/a6db2caea2a8ec518ede4b8b4b95222e52c42966" alt=""
するとこんな感じで表示されます。少し文字が大きい。
data:image/s3,"s3://crabby-images/8a157/8a1576d30d60342f6870843f2f13f0c80c241da9" alt=""
CSSでスタイルを調整する
サブタイトルには<span>タグがあたっているのでこちらにCSSをあてれば完成です。
data:image/s3,"s3://crabby-images/b3742/b37421d9693373ca3fdf62e500312843a87892da" alt=""
できた!
data:image/s3,"s3://crabby-images/6b66a/6b66ac6ab8146b00cc324f41dab8e09b7248e998" alt=""
その他のカスタマイズ
メニューの下にサブタイトルを表示させる
functions.phpに以下のコードを追記する
$1と{$item->attr_title}の位置が入れ替わっています。
add_filter('walker_nav_menu_start_el', 'description_in_nav_menu', 10, 4);
function description_in_nav_menu($item_output, $item){
return preg_replace('/(<a.*?>[^<]*?)</', "$1<br /><span>{$item->attr_title}</span><br><", $item_output);
}
できた!
data:image/s3,"s3://crabby-images/c6738/c673891e875c56f4f5bc1087a8dcee253577e8a9" alt=""
フォーム名を「タイトル属性」→「説明」にする
そもそもタイトル属性とは、マウスホバー時に表示するテキスト用に使われる要素だそうな。(自信ない)
また、サブタイトルを入力する項目として、「タイトル属性」より「説明」の方が分かりやすいと思ったので、項目名を「説明」に変更します。
functions.phpに以下のコードを追記する
add_filter('walker_nav_menu_start_el', 'description_in_nav_menu', 10, 4);
function description_in_nav_menu($item_output, $item){
return preg_replace('/(<a.*?>[^<]*?)</', "<br /><span>{$item->description}</span><br>$1<", $item_output);
}
前述したコードの{$item->attr_title}部分が{$item->description}に変わっています。
表示オプション→説明にチェックを入れる
data:image/s3,"s3://crabby-images/b3baf/b3baf59413466508528bd83449dc7cf0299bd1d6" alt=""
メニューの項目に「説明」が表示されるのでこちらにサブタイトルを入力する
data:image/s3,"s3://crabby-images/e7dd7/e7dd783bc240a8fd595a805b83660a8f4a6c9b6c" alt=""
この方法でも表示されます。
おしまい
暗号のように見えていたPHPですが、いくらか暗号ではなくなってきたような気がします。
自分なりに調べて少しカスタマイズできて嬉しかった記念の記事でした。お読みいただきありがとうございます!