Trusted WordPress tutorials, when you need them most.
Beginner’s Guide to WordPress
WPBカップ
25 Million+
Websites using our plugins
16+
Years of WordPress experience
3000+
WordPress tutorials
by experts

WordPressでメニューに条件ロジックを追加する方法(ステップバイステップ)

WordPressでは、ページごとに異なるメニュー項目を表示させたい場合があります。あるいは、ログイン中のユーザーのためだけの特別なメニューが欲しい場合もあるでしょう。

WordPressの初期設定では、テーマのどこにいても同じメニューが表示されます。この画一的なアプローチは必ずしも理想的とは言えません。

この投稿では、メニューに条件ロジックを追加する方法を説明します。こうすることで、特定の条件に基づいて訪問者が見るものをカスタマイズすることができます。

How to Add Conditional Logic to Menus in WordPress

なぜWordPressのメニューに条件ロジックを追加するのか?

ナビゲーションメニューはWordPressサイトに構造を与え、訪問者が探しているものを見つけやすくします。初期設定では、WordPressサイトはすべてのユーザー、すべての投稿とページに同じナビゲーションメニューを表示します。

しかし、ユーザーやサイト内のページによって異なるメニューを表示したい場合もあるでしょう。

オンラインショップ、WordPressの会員制サイトコミュニティ、オンライン学習プラットフォームなどのサイトは、すべてパーソナライズされたナビゲーションメニューの恩恵を受けることができます。

条件付きロジックを使用すると、ログイン中のユーザーに対して追加のメニュー項目を追加することができ、ユーザーがアカウントを管理したり、購読を更新したり、購入したオンラインコースを表示したりすることができます。WordPressメニューのアクセスコントロールと考えてください。

それを念頭に置いて、WordPressのメニューに条件付きロジックを追加する方法を紹介します。このチュートリアルで扱うトピックは以下の通りです:

準備はいいかい?始めよう

WordPressで新規ナビゲーションメニューを作成する

最初のステップは、WordPressで表示したい追加ナビゲーション・メニューを作成することです。その後、条件ロジックを使って、各メニューを表示するタイミングを決めることができる。

ここからは、クラシックエディターとブロックエディターの両方について、WordPressに条件付きメニューを追加する方法を紹介する。

クラシックエディターを使ってWordPressで新規ナビゲーションメニューを作成する

この方法はクラシックテーマユーザーに有効です。

新規ナビゲーションメニューを作成するには、WordPressダッシュボードの外観 ” メニューページに移動するだけです。すでにナビゲーションメニューがあり、サイト上ですべてのユーザーに使用している場合は、これを初期設定メニューにすることができます。

Creating main menu

次に、「新規メニューを作成」リンクをクリックして、新しいメニュー項目を作成する必要があります。例えば、ログイン中のユーザーに表示するメニューと、WordPressの特定のページやカテゴリーに表示するメニューを作成することができます。

画面の左側に、あなたのサイトのページ一覧が表示されます。メニューに追加したいページにチェックを入れ、「メニューに追加」ボタンをクリックしてください。

Logged in menu

画面右側のメニュー項目をドラッグ&ドロップして並べ替えることもできる。

さらにページを進むと、メニューを表示する場所を選ぶことができます。しかし、今はこのメニューに場所を割り当てる必要はありません。それは次のステップで行います。

メニューの保存」ボタンをクリックして変更を保存することを忘れないでください。

メニュー作成の詳細については、WordPressでナビゲーションメニューを追加する方法についての初心者向けガイドをご覧ください。

FSEを使用してWordPressで新規ナビゲーションメニューを作成する

フルサイト編集(FSE)でブロックテーマに新しいナビゲーションメニューを作成するには、まずWordPressダッシュボードから外観 ” エディターに移動する必要があります。

中に入ったら、「ナビゲーション」タブをクリックして展開することができる。このガイドではTwenty-Twenty Threeのテーマを使用しています。

Expand the navigation tab

次に、「ナビゲーション」ラベルの横にある「編集」をクリックしましょう。画面上にサイトエディターが表示されます。

ここから、あとはすべて「+」アイコンをクリックしてナビゲーションメニュー項目を追加するだけです。すると、ドロップダウンメニューが表示され、オプションを選択することができます。

Add a navigation menu item in the full site editor

より詳細な手順については、WordPressでナビゲーションメニューを追加する方法をご覧ください。

WordPressでログイン中のユーザーに別のメニューを表示する

ユーザーがサイトにログイン中か否かに応じて、異なるナビゲーションメニューを表示することはしばしば便利です。

例えば、ログアウト中のユーザーのためにログインと登録リンクを含め、ログイン中のユーザーのためにメニューにログアウトリンクを追加することができます。

WooCommerceストアを運営しているのであれば、一般ユーザーには非表示になっている項目をカスタマイザーに含めることができます。

クラシックエディターでログイン中のユーザーに異なるメニューを表示する

始めるには、Conditional Menusプラグインをインストールして有効化する必要があります。詳しくはWordPressプラグインのインストール方法をご覧ください。

有効化したら、外観 ” メニューに移動し、「ロケーションの管理」タブに切り替えます。

Manage menu locations

ここから、利用可能なメニューの場所と現在表示されているメニューのリストが表示されます。これらは使用しているWordPressテーマによって異なります。

例えば、私たちのデモサイトでは、「プライマリメニュー」の場所に「メインメニュー」というナビゲーションメニューが表示されています。

特定の条件に一致したときに別のメニューを表示するようにプラグインに指示するには、「+条件付きメニュー」リンクをクリックし、ドロップダウン・メニューから別のメニューを選択します。

このチュートリアルでは、「ログイン中メニュー」を選択します。

Select logged in menu

次に、「+条件」のリンクをクリックする必要がある。

するとポップアップが表示され、たくさんの条件から選ぶことができる。

Select logged in user as the condition

ユーザーログイン中」オプションの横にあるボックスにチェックを入れ、「保存」ボタンをクリックするだけです。

あなたのサイトにアクセスして、ログイン中のユーザーメニューを実際に見ることができるようになりました。あなたのサイトからログアウト中、他のすべてのユーザーに表示されるナビゲーションメニューを見ることができます。

Different menu for logged in users

さらに詳しく、コードを使った方法を知りたい方は、WordPressでログイン中のユーザーに異なるメニューを表示する方法をご覧ください。

FSEを使用したログイン中ユーザーへの異なるメニューの表示

ブロックテーマを使っているなら、Conditional Blocksプラグインが必要だ。まずはプラグインをインストールして有効化しましょう。ヘルプが必要な場合は、WordPressプラグインのインストール方法のガイドを参照してください。

有効化した後、外観 ” エディターに移動してFSE機能を開くことができますそして、「パターン」をクリックし、次に「すべてのテンプレートパーツ」をクリックします。

これで、フッター、ヘッダー、コメントを含むテンプレートパーツがすべて表示されるはずです。ヘッダー」セクションの3つの点をクリックし、「編集」を選択しましょう。

Edit header button in FSE

これでブロックエディターにリダイレクトされます。

次に、条件を追加したいナビゲーション・メニューをクリックします。その後、右側のサイドパネルにある「ブロック」タブに切り替えるだけで、カスタマイザーが開始されます。

Switching to the block tab

ブロック」タブを下にスクロールすると、「条件付きブロック」のセクションがあります。これをクリックすると、カスタマイズオプションが表示されます。

次に、「Edit Visibility」ボタンをクリックします。

The Edit Visibility button in the block editor

選択したナビゲーション・メニューの条件を設定するポップアップ・ウィンドウが表示されます。

ここで、’CONDITION’ドロップダウンを開き、’User Logged In’オプションを選択します。

Setting conditions in the block editor

右上の「X」ボタンをクリックしてウィンドウを閉じます。

すると、「条件ブロック」セクションに条件が追加されるはずです。保存」をクリックして、ナビゲーション・メニューを更新してください。

さて、あなたのサイトにアクセスした場合、ログアウト中とログイン中のユーザーではどのように見えるでしょうか:

Live website preview of logged out and logged in users

ユーザー権限グループによって異なるWordPressメニューを表示する

ユーザーがログイン中、割り当てたユーザー権限グループによって異なるナビゲーションメニューを表示することもできます。

例えば、管理者には特別なメニュー項目を、寄稿者にはより限定された項目を含めることができます。会員制サイトでは、会員レベルによって異なるアクセスレベルを与えることができます。

クラシックエディターでユーザー権限グループによって異なるWordPressメニューを表示する

前のセクションと同様に、Conditional Menusプラグインをインストールして有効化する必要があります。

次に、外観 ” メニューのページで、「場所の管理」タブに切り替えます。

Select the Conditional Menu

選択したユーザー権限グループに適切な条件メニューを追加する必要があります。このチュートリアルでは、’Nav Menu Administrator’メニューを選択します。

その後、「+条件」リンクをクリックして、ユーザー権限を選択することができます。

Select the Roles That Should See the Menu

サイトの各ユーザー権限グループのチェックボックスを表示するには、「ユーザー権限」タブをクリックする必要があります。このメニューが表示されるユーザー権限グループをクリックし、「保存」ボタンをクリックして変更を保存します。

FSEを使用してユーザー権限グループによって異なるWordPressメニューを表示する

FSEのユーザー権限グループによって異なるメニューを表示するには、コンテンツコントロールプラグインを使用します。プラグインのインストールと有効化については、WordPressプラグインのインストール方法をご覧ください。

有効化したら、外観 ” エディター ” パターン ” すべてのテンプレートパーツを開きます。次に、「ヘッダー」セクションの3つの点をクリックし、「編集」を選択するだけです。

Edit header button in FSE

エディターでは、条件を追加するナビゲーション・メニューを選択できる。

例えば、「ブログ」ページを購読者だけに限定することにします。そこで、「ブログ」をクリックして、カスタマイズ設定を開きます。

ここから右側のパネルに移動し、「ブロックコントロール」セクションの「コントロールを有効化」スイッチを切り替えよう。

Enabling controls for assigning user roles for menu

次に、「ユーザールール」セクションまでスクロールダウンして、条件を設定します。

まず、’WHO CAN SEE THIS CONTENT’ドロップダウンメニューを開き、’Logged In User’を選択します。

次に、「USER ROLE」のドロップダウンで、「Matching」を選択します。そして’CHOSEN ROLES’では’購読者’を選択しよう。

Assigning user role conditions

完了したら、「保存」ボタンをクリックします。

WordPressでページごとに異なるメニューを表示する

WordPressでは、ページごとに異なるメニューを表示することができます。例えば、プライバシーポリシーページに Cookie通知へのリンクのような特別なメニュー項目を表示することができます。

クラシックエディターを使ってWordPressでページごとに異なるメニューを表示する

そのためには、Conditional Menusプラグインをインストールして有効化する必要があります。その後、外観 ” メニュー ロケーションの管理に移動します。

適切なナビゲーション・メニューを選んだら、「+条件」リンクをクリックします。今回は、「ページ」タブをクリックしてください。あなたのサイトのすべてのページのリストが表示されます。

Select the Pages Where the Menu Should Be Displayed

ナビゲーション・メニューを表示したい各ページの横にチェックマークを入れます。完了したら、「保存」ボタンをクリックしてください。

FSEを使用してWordPressでページごとに異なるメニューを表示する

ブロックテーマのユーザーは、Block Visibilityプラグインを使用できます。インストールにお困りの場合は、WordPressプラグインのインストール方法をご覧ください。

有効化したら、外観 ” エディター ” パターン ” すべてのテンプレートパーツに移動しましょう。そして、ヘッダーのエディターを開いたら、「表示」セクションに進みます。

ここからドロップダウンを開き、「URLパス」を選択します。

Selecting the URL Path option in block editor

次に、プライバシーポリシーページのURLパスを「URL PATH (CONTAIN)」エリアに追加します。

URLパスとは、ウェブアドレスのうち、メインのサイト名の後に来る部分で、特定のページや項目を示す。

例えば、アドレスhttps://example.co m/about、/aboutの部分がURLパスとなる。

Adding a URL Path for conditional menu

プライバシーポリシーページのURLパスがわからない場合は、ページ ” すべてのページに移動することができます。そして、プライバシーポリシーのページを見つけてマウスオーバーしてください。

クイック編集」ボタンをクリックすると、「スラッグ」セクションが表示されます。URLパスは、’/’記号の後にページのスラッグが続くようにします。

A page's slug

または、ページにアクセスし、ドメイン名の後のビットをコピー&ペーストするだけ。

これで完了です!保存」をクリックして変更を保存してください。

WordPressでランディングページのナビゲーションメニューを非表示にする

ランディングページなど、ナビゲーションメニューをすべて表示したくないページがサイト内にあるかもしれません。

ランディングページは、ビジネスの売上を伸ばしたり、リードを生み出したりするためにデザインされます。このようなページでは、気を散らすものを最小限に抑え、ユーザーが特定のアクションを起こすために必要な情報をすべて提供したいと思うでしょう。

ランディングページのコンバージョンを300%増加させる方法についてのガイドでは、ナビゲーションメニューやその他のリンクをページから削除することで、気が散るのを最小限に抑えることを提案しています。

クラシックエディターを使ってWordPressのランディングページのナビゲーションメニューを非表示にする

そのためにはConditional Menusプラグインを使います。今回は、条件付きメニューを選択するときに、ドロップダウンから「メニュー無効化」を選びます。

Select Disable Menu From the Drop Down

次に、「+条件」リンクをクリックして、メニューを表示するタイミングを選択しよう。

ページ」タブをクリックし、「マイランディングページ」項目の横にチェックマークを付ける。

Select the Pages Where the Navigation Menu Should Be Hidden

設定を保存して適用するには、「保存」ボタンをクリックするのをお忘れなく。

FSEを使用してWordPressのランディングページのナビゲーションメニューを非表示にする

さて、ブロックテーマユーザーの場合は、Block Visibilityプラグインを使いますが、今回は「URL Path (Does Not Contain)」フィールドにURLパスを入力します。

それでは、プラグインをインストールして有効化しましょう。ヘルプが必要な場合は、WordPressプラグインのインストール方法のガイドをご覧ください。

有効化したら、外観 ” エディター ” パターン ” すべてのテンプレートパーツにアクセスしてください。ヘッダー・エディター内に入ったら、「表示」セクションを探しましょう。

ここから「URLパス」を選択し、「URLパス(コンテナなし)」フィールドにランディングページのパスを入力します。

Hiding landing page

完了したら、「保存」ボタンをクリックするだけです。

WordPressのナビゲーションメニューをもっと活用しよう

ナビゲーションメニューは強力なウェブデザインツールです。ユーザーをサイトの最も重要なセクションに誘導することができます。

ページやユーザーごとに異なるナビゲーションメニューが表示されるようになった今、さらにカスタマイズするにはどうすればいいのか悩むかもしれません。

ナビゲーションメニューの機能を強化するには、以下のチュートリアルをご覧ください。これらのチュートリアルは、あなたのWordPressサイトを次のレベルに引き上げるのに役立ちます:

このチュートリアルで、WordPressのメニューに条件ロジックを追加する方法を学んでいただけたでしょうか。次は、WordPressのメニューにページへのリンクを張らずにタイトルを追加する方法や、WordPressでパンくずナビゲーションリンクを表示する方法を学びたいと思うかもしれません。

If you liked this article, then please subscribe to our YouTube Channel for WordPress video tutorials. You can also find us on Twitter and Facebook.

情報開示 私たちのコンテンツは読者支援型です。これは、あなたが私たちのリンクの一部をクリックした場合、私たちはコミッションを得ることができることを意味します。 WPBeginnerの資金源 をご覧ください。3$編集プロセスをご覧ください。

アバター

Editorial Staff at WPBeginner is a team of WordPress experts led by Syed Balkhi with over 16 years of experience in WordPress, Web Hosting, eCommerce, SEO, and Marketing. Started in 2009, WPBeginner is now the largest free WordPress resource site in the industry and is often referred to as the Wikipedia for WordPress.

究極のWordPressツールキット

ツールキットへの無料アクセス - すべてのプロフェッショナルが持つべきWordPress関連製品とリソースのコレクション!

Reader Interactions

36件のコメント返信を残す

  1. Syed Balkhi says

    Hey WPBeginner readers,
    Did you know you can win exciting prizes by commenting on WPBeginner?
    Every month, our top blog commenters will win HUGE rewards, including premium WordPress plugin licenses and cash prizes.
    You can get more details about the contest from here.
    Start sharing your thoughts below to stand a chance to win!

  2. Bet Hannon says

    Be VERY careful with making menus different across your site. It’s not a problem to show different menus to logged in/out users, but to meet WCAG 2.0+ accessibility standards, main menus should be consistent page to page.

    • WPBeginner Support says

      Thank you for sharing that for those attempting to have those standards for their site. :)

      管理者

  3. Kevin says

    I don’t see the “Enable conditional logic” under Appearance -> Menu. I’m using WordPress 5.7 as of March 16, 2021.

    • WPBeginner Support says

      The wording may have changed since this article but there should still be a checkbox for changing the visibility.

      管理者

  4. Richard S. says

    BIG Thank you for this article, it’s awesome.
    Your snippet of code was perfect for a project I was working on, as was this plugin which I’m now using.
    Even in 2019 this is a handy page, it’s working well on WordPress 5.2.3 (Astra Pro theme) so still very applicable.

  5. Vasim Shaikh says

    I would like to ask I have added role for user Author and subscriber both then its should be display to author not subscriber. how to handle this?

  6. Rudolf says

    Really simple and easy to use plugin. Fantastic! It did not only save me a lot of time but also an organizational advantage because instead of using widget logic with different menu widgets, I create now one 1 menu with conditions per item.

  7. Jonathan P says

    Thank you,

    I have only used this plugin for conditions for users that are logged in or not logged in, but it works great, it really has saved me hours of messing around with code.

  8. Kiva says

    Could I set up this plugin so that I can set up different menu options for each different category?

  9. David says

    Thank you guys for sharing this. However it will display a PHP Notice on conditioned menu items and the custom condition won’t be displayed among condition options, if you don’t specify the id parameter.

  10. Paul says

    Hi, I added conditions (if a string matches the server name, a menu is hidden). Great! But I would like to add even more custom conditions. Could you show an example of the code you would use to add more than on name/condition pair the custom option?

    name = “If the site is not www.”
    condition = www is not in SERVER_NAME
    name = “Paul site.”
    condition = “paul is in SERVER_NAME”

    etc.

    Thanks!

  11. Isuru says

    This Conflicts the WP User Manager Pro, and then user manager Pro plugin functions not working due to the confliction.
    as an ex: Show password tick in user registration page doesn’t work, as well as login page also not functioning well.
    can you please fix this

  12. Mo says

    Yep, definitely broken.

    Works great for the built in conditions, but when coding custom conditions it works once and then stops working.

  13. jban says

    YES!!! After 90 minutes of trying to figure this out, this article made it work for me. THANK YOU!!!

  14. Mohi says

    Hello
    I installed this plugin, but I am getting an warning as follows :

    Warning: Missing argument 2 for custom_nav_edit_walker() in /var/www/equest/wp-content/themes/wp-questrian/framework/megamenu/mega-menu.php on line 42

    How to solve this warning ? Please guide me.

  15. JMD says

    I have not used the If Menu plugn, but I tried the Nav Menu Roles plugin

    It works but then conflicts with the Mega menu functionality of my theme.

    I am hesitant to try the If Menu plugin mainly because it has not been updated in so long. It will be a matter of time before I have to remove it for sure.

  16. Peter says

    Could not get this plugin to work. Not showing up i menu-items. Using: WP 4.3 / Nimwa theme.

    Any suggestions on similar working plugin? Just want to hide some menu items while working on them…

  17. Chuks Eke says

    Hi,
    Could this be achieved with this plugin,
    I want to have different menu for different pages or post. for example,

    Home | About Us | Service | Contact

    About Us [ History | Team | Career ]
    Services [ Web Development | Window Application | Corporate ID ]

    Is it possible with this plugin to show sub menu on side menu for About Us

      • Dieter says

        I stopped installation after reading WP Org PlugIn Page, there is the comment “1 person says it is broken” and in the support section is an open report which is not solved.
        If I read something like this I don’t even try to install such plug in.

      • Jagabandhu says

        The plugin is not working. It’s not showing “enable conditional logic” and the plugin author is not responding from last 7 months.

        Tried with disabling other plugins. But no result.

        Is there any other plugin to do so!?
        I need it.

返信を残す

コメントありがとうございます。すべてのコメントは私たちのコメントポリシーに従ってモデレートされ、あなたのメールアドレスが公開されることはありませんのでご留意ください。名前欄にキーワードを使用しないでください。個人的で有意義な会話をしましょう。