WordPressカスタムメニューからIDやクラスを削除する方法
MENU
  1. HOME
  2. WordPress / カスタマイズ
  3. WordPressカスタムメニューからIDやクラスを削除する方法

最近の作業実績

  • 2022年10月18日不要になっていたコンテンツをサイト内から除去いたしました。
  • 2022年10月17日サイト内の画像が表示されない不具合を修正いたしました。
  • 2022年10月16日サイト内で発生した大量の404エラーを修正いたしました。
  • 2022年10月15日既存サイトの各所を簡単に更新できる機能を追加いたしました。
  • 2022年10月14日過去記事を定期的に自動ツイートする機能をテーマに実装いたしました。
  • 2022年10月13日サイト内の広告を一括管理できる機能をテーマに実装いたしました。
  • 2022年10月12日既存サイトのトップページを再構築いたしました。
  • 2022年10月11日クラシックエディターで管理されていたコンテンツをブロックエディターで再構築いたしました。
  • 2022年10月10日複数のサイトの更新情報を一括表示させる機能をテーマに実装いたしました。
  • 2022年10月09日WordPressの管理画面にオリジナルの管理ページを実装いたしました。
  • 2022年10月08日コンタクトフォーム7で構築されたフォームに確認画面とサンクスページを導入いたしました。
  • 2022年10月07日既存サイトのサーバー移管を担当いたしました。
  • 2022年10月06日フッターのレイアウトを再設計いたしました。
  • 2022年10月05日既存サイトのカラーを一括管理できる機能をテーマに実装いたしました。
  • 2022年10月04日新規ページを5ページ作成いたしました(デザイン込み)。
  • 2022年10月03日訪問者に閲覧履歴を表示する機能をテーマに実装いたしました。
  • 2022年10月02日ログインできなくなったWordPressを復旧いたしました。
  • 2022年10月01日オリジナルテーマの制作を担当いたしました。
  • 2022年09月30日破損していたテーマを修正いたしました。
  • 2022年09月29日アフィリエイト審査用のサイト立ち上げを担当いたしました。
  • このエリアには直近の制作実績を一部掲載しております。
  • 制作実績はリアルタイム反映ではありません。

WordPressカスタムメニューからIDやクラスを削除する方法

この投稿は2021/07/14に加筆修正いたしました。

WordPressのカスタムメニューで自動的に付与されるIDやクラスを削除する方法に興味はありませんか?これらのIDやクラスは、簡単なカスタマイズで削除することができるで、その方法を解説してみました。興味のある方は参考にしてください。

この記事は約 9 分で読めます。

メニューを囲っているDIV要素とUL要素のIDを削除する方法

メニューを囲っているDIV要素とUL要素のIDを削除する場合、テーマに記述しているカスタムメニューを出力するコードをカスタマイズしてやります。

<?php wp_nav_menu(); ?>をカスタマイズする

メニューを囲っているDIV要素とUL要素のIDを削除する場合、カスタムメニューを表示させる箇所に記載している以下のコードをカスタマイズしてやります。

<?php wp_nav_menu(); ?>

上記のコードを以下のようにカスタマイズしてやりましょう。

<?php wp_nav_menu(
array(
'theme_location' => '********',
'container' => false ,
'items_wrap' => '<ul>%3$s</ul>'
)
); ?>

参考:memocarilog

【********】部分には、表示させたいメニューのロケーション名に置き換えてください。

上記の様にコードをカスタマイズしてやると、メニューを囲っているDIV要素とUL要素のIDを削除することができます。

'container' => false ,

上記のように【container】を【false】にすることで、カスタムメニューを囲っているDIV要素を削除することができます。

'items_wrap' => '<ul>%3$s</ul>'

【items_wrap】を【<ul>%3$s</ul>】にすることで、UL要素のIDを削除することができます。

メニューを囲っているDIV要素とUL要素のIDを削除されたのを確認してみる

メニューを囲っているDIV要素とUL要素のIDを削除されたのを確認してみましょう。
<?php wp_nav_menu(); ?>をカスタマイズしたことで、以下の様な変化が生じます。

<div class="******">
<ul id="******" class="menu">
<li id="******" class="******"><a href="******" aria-current="page">メニュー項目</a></li>
<li id="******" class="******"><a href="******">メニュー項目</a></li>
<li id="******" class="******"><a href="******">メニュー項目</a></li>
<li id="******" class="******"><a href="******">メニュー項目</a></li>
<li id="******" class="******"><a href="******">メニュー項目</a></li>
</ul>
</div>

上記のように出力されていたメニューが以下のようになります。

<ul>
<li id="******" class="******"><a href="******" aria-current="page">メニュー項目</a></li>
<li id="******" class="******"><a href="******">メニュー項目</a></li>
<li id="******" class="******"><a href="******">メニュー項目</a></li>
<li id="******" class="******"><a href="******">メニュー項目</a></li>
<li id="******" class="******"><a href="******">メニュー項目</a></li>
</ul>

メニューを囲っていたDIV要素と、UL要素に付与されていたIDとクラスが削除されました。

メニューを囲っているDIV要素とUL要素のIDを削除する方法は以上です。

LI要素のIDとCLASSを削除する方法

次にメニューのLI要素に付与されているIDとクラスを削除する方法をご紹介します。
こちらは、functions.phpにコードを追記していきます。

  • LI要素に付与されているIDを削除する方法
  • LI要素に付与されているCLASSを削除する方法

個別にみていきましょう。

LI要素に付与されているIDを削除する方法

LI要素に付与されているIDを削除したい場合、以下のコードをfunctions.phpに追記します。

function my_nav_menu_id( $menu_id ){
$id = NULL;
return $id;
}
add_filter( 'nav_menu_item_id', 'my_nav_menu_id' );

上記のコードをfunctions.phpに追記する事で、以下のように付与されているIDを削除できます。

<ul>
<li id="******" class="******"><a href="******" aria-current="page">メニュー項目</a></li>
<li id="******" class="******"><a href="******">メニュー項目</a></li>
<li id="******" class="******"><a href="******">メニュー項目</a></li>
<li id="******" class="******"><a href="******">メニュー項目</a></li>
<li id="******" class="******"><a href="******">メニュー項目</a></li>
</ul>

上記のように出力されていたメニューが以下のようになります。

<ul>
<li class="******"><a href="******" aria-current="page">メニュー項目</a></li>
<li class="******"><a href="******">メニュー項目</a></li>
<li class="******"><a href="******">メニュー項目</a></li>
<li class="******"><a href="******">メニュー項目</a></li>
<li class="******"><a href="******">メニュー項目</a></li>
</ul>

LI要素に付与されていたIDが削除されました。

LI要素に付与されているCLASSを削除する方法

LI要素に付与されているクラスを削除したい場合、以下のコードをfunctions.phpに追記します。

function my_nav_menu_class( $classes, $item ){
if( $classes[0] ){
array_splice( $classes, 1 );
}else{
$classes = [];
}
if( $item -> current == true ){
$classes[] = 'current';
}
return $classes;
}
add_filter( 'nav_menu_css_class', 'my_nav_menu_class', 10, 2 );

参考:BLOG AND DESTROY

上記のコードをfunctions.phpに追記すれば、以下のように付与されているCLASSを削除できます。

<ul>
<li class="******"><a href="******" aria-current="page">メニュー項目</a></li>
<li class="******"><a href="******">メニュー項目</a></li>
<li class="******"><a href="******">メニュー項目</a></li>
<li class="******"><a href="******">メニュー項目</a></li>
<li class="******"><a href="******">メニュー項目</a></li>
</ul>

上記のように出力されていたメニューが以下のようになります。

<ul>
<li><a href="******" aria-current="page">メニュー項目</a></li>
<li><a href="******">メニュー項目</a></li>
<li><a href="******">メニュー項目</a></li>
<li><a href="******">メニュー項目</a></li>
<li><a href="******">メニュー項目</a></li>
</ul>

LI要素に付与されていたクラスが削除されました。

補足:LI要素に付与されているCLASSを削除する方法

LI要素に付与されているCLASSを削除する方法でご紹介したコードですが、単純にLI要素に付与されているクラスを消すだけではありません。実用性を兼ねて、以下の処理も加わっています。

  • 管理画面から設定したクラスは適応される。
  • 表示されているページがメニューにある場合、クラス【current】を付与する。

独自のクラスを適応したい場合はあるかと思いますので、管理画面から設定したクラスは適応されるようになっています。

カレント表示の際、メニューのデザインを変更することもあると思いますので、クラス【current】が自動的に付与されるようになっております。

まとめ

WordPressカスタムメニューからIDやクラスを削除する方法をご紹介しました。

  • メニューを囲っているDIV要素とUL要素のIDを削除する方法
  • LI要素に付与されているIDを削除する方法
  • LI要素に付与されているCLASSを削除する方法

いずれも簡単なコピペだけで行える簡単なカスタマイズです。
カスタムメニューのIDやクラスを削除したい方は挑戦してみてください。

Wordpressのカスタマイズや不具合など
何かお困りのことはありませんか?

Wordpressに関連するあなたのお悩み、解決いたします。
次のような方は、お気軽にご相談下さい。

  • Wordpressサイトをカスタマイズしたいが、やり方が分からないで困っている。カスタマイズの知識が豊富な人に任せたい。
  • Wordpressサイトに不具合が発生したが、直し方が分からない。不具合の修正経験が豊富な人に任せたい。
  • 既存サイトにWordPressを導入したいが、やり方が複雑で自分ではできそうにもない。経験が豊富な人に任せたい。
  • WordPressがハッキングされたが修正の仕方が分からない。サイトを元通りにできる人を探している。
  • Wordpressで0からサイトを制作したいが、自分ではできそうにもない。プロにサイト制作を委託したい。

一つでも該当する方は、以下のフォームからお気軽にご相談下さい。

WordPressに関して今すぐ相談する

著者:takaya kondo

岡山在住のWordPress専門フリーランサーです。Wordpressを使ったWEBサイト制作を中心に10年間ほど活動させていただいています。

Wordpress関連の記事でお役に立てれば幸いです。

【関連記事】あなたが興味のありそうな関連記事をご紹介します。

コメントを残す

(必須)

CAPTCHA