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

WordPressテーマでカスタムナビゲーションメニューを追加する方法

WPBeginnerでは、ユーザーエクスペリエンスを向上させ、ブランディングを強化し、コンバージョンを促進するために、数え切れないほどの読者がWordPressサイトをカスタマイズするお手伝いをしてきました。そして、ナビゲーションメニューを適切に作成することで、エンゲージメントを高め、サイトを長く利用してもらうことができることを実感してきました。

問題は、WordPressテーマはすべてナビゲーションメニューを表示できる場所が決まっているため、これを変更するのが厄介だということだ。テーマファイルを修正するのは繊細な作業なので、初心者の場合は特にそうだ。

ブロックテーマを使用している場合、フルサイトエディターでこれを行うことができます。しかし、私たちの経験では、すべてのタイプのテーマで機能する、より良いオプションがあります。

例えば、高度なカスタマイザーが必要であれば、SeedProdのような強力なページビルダーを使うことができます。また、カスタマイザーをシンプルに使いたいのであれば、WPCodeが断然おすすめです。

この投稿では、WordPressテーマの任意のエリアにカスタムナビゲーションメニューを追加する方法を紹介します。あなたのニーズに合ったチュートリアルを選択できるように、3つの異なるオプション設定について説明します。

How to add custom navigation menus in WordPress themes

なぜWordPressテーマでカスタムナビゲーションメニューを追加するのですか?

ナビゲーションメニューは、サイトの重要なエリアを指すリンクのリストです。訪問者が興味深いコンテンツを見つけやすくすることで、WordPressのページビューを増やし、直帰率を下げることができます。

メニューの正確な位置はWordPressテーマによって異なります。ほとんどのテーマにはいくつかのオプションがあるので、異なるメニューを作成し、異なる場所に表示することができます。

現在のWordPressテーマでメニューを表示できる場所を確認するには、外観 ” メニューに移動し、「表示場所」セクションを見てください。

以下の画像は、Astra WordPressテーマでサポートされている場所を示しています。

The menu locations in the popular Astra theme

テーマで「表示場所」としてリストされていないエリアにメニューを表示したい場合があります。

それでは、WordPressテーマのどのエリアにもカスタムナビゲーションメニューを追加する方法を見ていきましょう。以下のクイックリンクからお好きな方法にジャンプしてください:

方法1:フルサイトエディターを使う(ブロックベースのテーマのみ)

ThemeIsle Hestia Proのようなブロックテーマを使っている場合、フルサイト編集(FSE)とブロックエディターを使ってカスタムナビゲーションメニューを追加することができます。

詳しくはWordPressフルサイト編集テーマの投稿をご覧ください。

この方法はすべてのテーマで使えるわけではないし、メニューのすべての部分をカスタマイズできるわけでもない。WordPressテーマに完全にカスタムメニューを追加したい場合は、代わりにページビルダープラグインを使用することをお勧めする。

ブロックベースのテーマを使っている場合は、外観エディターへ

Opening the WordPress full-site editor (FSE)

デフォルト設定では、フルサイトエディターにはテーマのホームテンプレートが表示されますが、どのエリアにもナビゲーションメニューを追加することができます。

利用可能なオプションをすべて見るには、「テンプレート」、「パターン」、「ページ」のいずれかを選択すればよい。

Adding a custom navigation menu to a WordPress block-based theme

カスタムナビゲーションメニューを追加したいテンプレート、テンプレートパーツ、ページをクリックしてください。

WordPressにデザインのプレビューが表示されます。このテンプレートを編集するには、小さな鉛筆のアイコンをクリックしてください。

Adding a navigation menu to a 404 page template

次のステップは、メニューを表示したいエリアにナビゲーションブロックを追加することです。

左上の青い「+」ボタンをクリックする。

Adding blocks to your WordPress theme

では、検索バーに「ナビゲーション」と入力してください。

ナビゲーション」ブロックが外観に表示されたら、レイアウトにドラッグ&ドロップするだけです。

The WordPress Navigation block

次に、ナビゲーションブロックをクリックして選択します。

表示したいメニューがすでに作成されている場合は、ナビゲーションブロックをクリックして選択します。右側のメニューで、「メニュー」の隣にある3点アイコンをクリックします。

Adding menus to a WordPress theme using the full-site editor (FE)

ドロップダウンメニューからメニューを選択することができます。

もう一つのオプションは、ページ、投稿、カスタムリンクなどを追加して、フルサイトエディター内でメニューを構築することです。新規メニューに項目を追加するには、’+’アイコンをクリックするだけです。

How to build a new menu in the block editor

このポップアップを開き、任意の投稿やページを追加し、これらのリンクを新しいタブで開くかどうかを決定します。

WordPressのメニューに検索バーを追加したり、ソーシャルメディアのアイコンを追加したりすることもできます。ポップアップで、メニューに追加したいブロックをタイプし、適切なオプションが表示されたら選択するだけです。

Adding a search bar to a WordPress navigation menu

その後、ミニツールバーと右側メニューの設定を使用して、このブロックを設定することができます。メニューに項目を追加するには、この手順を繰り返すだけです。

メニューの見た目に満足したら、「保存」ボタンをクリックするだけです。

How to add custom navigation anywhere in a WordPress theme

あなたのサイトは新しいテンプレートを使用するようになり、訪問者はカスタムナビゲーションメニューを操作できるようになります。

方法2:ページビルダー・プラグインを使う(すべてのテーマで使える)

フルサイトエディターでは、ブロックベースのテーマにメニューを追加することができる。しかし、高度で完全にカスタマイズ可能なメニューをWordPressテーマに追加したい場合は、ページビルダープラグインが必要です。

SeedProdは、あなたのナビゲーションメニューのすべての部分をカスタマイズすることができ、市場で最高のWordPressページビルダープラグインです。

私たちは、このツールを使ってカスタムナビゲーションメニューやランディングページなどを構築した豊富な経験があります。詳細については、SeedProdのレビューをご覧ください。

ページに関しては、SeedProdには350以上のプロがデザインしたテンプレートが用意されています。テンプレートを選択した後、SeedProdの既製のナビゲーションメニューブロックを使用してサイトにカスタマイザーナビゲーションメニューを追加することができます。

まず、SeedProdプラグインをインストールして有効化する必要があります。詳しくは、WordPressプラグインのインストール方法のステップバイステップガイドをご覧ください。

注:コードを書かずにカスタマイザーナビゲーションメニューを作成できるSeedProdの無料版もあります。しかし、このガイドでは、SeedProd Proを使用します。SeedProd Proには、ナビゲーションメニューブロックに加えて、追加のテンプレートと高度な機能があります。

プラグインを有効化した後、SeedProdはライセンスキーを要求します。

SeedProd license key

この情報は、SeedProdサイトのアカウントで確認できます。キーを入力した後、「Verify Key」ボタンをクリックしてください。

それができたら、SeedProd ” ランディングページに行き、’新規ランディングページを追加’ボタンをクリックします。

SeedProd's page design templates

カスタムページのテンプレートを選択できます。

適切なデザインを見つけるために、SeedProdのテンプレートはすべて、近日公開キャンペーンやリードスクイーズキャンペーンなど、さまざまなキャンペーンタイプに分類されています。SeedProdのテンプレートを使って404ページを改善することもできます。

The SeedProd template library

デザインを詳しく見るには、テンプレートの上にマウスオーバーし、虫眼鏡アイコンをクリックするだけです。

使いたいデザインが見つかったら、「Choose This Template」をクリックする。

Choosing a SeedProd template for your WordPress website

すべての画像に「ブラックフライデー販売ページ」テンプレートを使用していますが、お好きなテンプレートをお使いください。

テンプレートを選択したら、カスタムページの名前を入力します。SeedProdはページのタイトルに基づいて自動的にURLを作成しますが、このURLは好きなものに変更することができます。

例えば、検索エンジンがページの内容を理解しやすくするために、関連キーワードを追加することもできます。これはWordPressのSEOを改善し、検索エンジンがあなたのようなコンテンツを探している人にページを表示するのに役立ちます。

これらの情報を入力したら、「保存してページの編集を開始する」ボタンをクリックします。

Creating a new page using SeedProd

ほとんどのテンプレートはすでにいくつかのブロックを含んでおり、これらはすべてSeedProdページレイアウトのコアコンポーネントです。

ブロックをカスタマイズするには、ページエディターでクリックして選択するだけです。

左側のツールバーには、そのブロックのすべての設定が表示されます。例えば、下の画像では「見出し」ブロック内のテキストを変更しています。

Editing a headline in SeedProd

左側のメニューにある設定を使って、テキストの書式設定、配置の変更、リンクの追加などができます。

高度な」タブを選択すると、さらに多くの設定にアクセスできるようになります。例えば、ボックスシャドウや CSSアニメーションを追加して、ブロックを本当に目立たせることができます。

デザインに新しいブロックを追加するには、左側のメニューからブロックを探し、ページ上にドラッグするだけです。ブロックを削除したい場合は、クリックしてブロックを選択し、ゴミ箱内のアイコンを使用します。

Removing blocks from a custom layout

カスタマイザーナビゲーションメニューを作りたいので、「Nav Menu」ブロックをページにドラッグする。

これにより、初期設定の「About」項目が個別設定されたナビゲーションメニューが作成されます。

Adding a custom navigation menu to a WordPress layout

SeedProdエディター内で新しいメニューを作成するか、WordPressダッシュボードですでに作成したメニューを選択することができます。

以前作成したメニューを表示するには、「WordPressメニュー」ボタンをクリックしてください。メニュー’ドロップダウンを開き、リストから任意の設定を選択することができます。

How to create a menu using SeedProd

その後、左側のメニューにある設定を使って、フォントサイズや文字揃えなどを変更できる。

SeedProdの中に新しいメニューを作りたい場合は、’Simple’ボタンを選択してください。

How to create a navigation menu using SeedProd

次に、SeedProdが初期設定として作成する「About」項目をクリックして展開します。

テキストを変更したり、メニュー項目がリンクするURLを追加したりできるコントロールが開きます。

Adding a custom navigation menu to a landing page

初期設定では、リンクは「dofollow」になり、同じブラウザーウィンドウで開きます。これらの設定は、「URLリンク」セクションのチェックボックスを使って変更できます。

以下の画像では、新しいウィンドウで開く「nofollow」リンクを作成しています。このトピックについては、nofollowリンクの初心者ガイドをご覧ください。

Marking a menu item as no-follow

メニューに項目を追加するには、「新規項目を追加」ボタンをクリックします。

その後、上記と同じプロセスを踏むことで、各項目をカスタマイズすることができる。

Adding items to a custom navigation menu

左側のメニューには、フォントサイズやテキストの配置を変更する設定もある。

メニューの各項目の間に表示される区切りも作成できる。

Creating a divider for your custom navigation menu

その後、’Advanced’タブに切り替えてください。ここでは、メニューの色、間隔、タイポグラフィ、その他の高度なオプションを変更することができます。

変更を加えると、ライブプレビューが自動的に更新されるので、さまざまな設定を試して、あなたのデザインに何が似合うかを確認できます。

The SeedProd advanced customization settings

初期設定では、SeedProdはモバイル端末とデスクトップ端末で同じメニューを表示します。しかし、一般的にモバイル端末はデスクトップコンピューターに比べて画面が非常に小さいです。

その点を考慮すると、モバイル端末で表示するメニューを区切った方がいいかもしれません。例えば、モバイルユーザーが横にスクロールする必要がないように、縦長のレイアウトにするとよいでしょう。また、スマートフォンやタブレット端末では、表示するリンクを少なくするのもよいでしょう。

モバイル対応メニューを作成するには、上記と同じ手順に従ってメニューをデザインするだけです。次に、’詳細設定’タブを選択し、’端末の表示’セクションをクリックして展開します。

How to create a mobile-only menu in SeedProd

デスクトップに非表示」スライダーの切り替えができるようになりました。

現在、SeedProdはこのメニューをモバイルユーザーにのみ表示します。

Hiding a menu on desktop devices

カスタムメニューの見た目に満足したら、公開しましょう。

保存」の隣にあるドロップダウン矢印をクリックし、「公開する」を選択するだけです。

How to publish a custom page layout

これで、WordPressブログにアクセスすると、カスタムナビゲーションメニューが表示されます。

方法3:WordPressでコードを使用してカスタムナビゲーションメニューを作成する(上級者向け)

ページビルダープラグインをセットアップしたくない場合は、コードを使ってカスタマイザーナビゲーションメニューを追加することができます。テーマのfunctions.phpファイルにカスタムコードスニペットを追加する方法を説明したガイドがよく見つかるだろう。

しかし、この方法はお勧めしません。コードにちょっとしたミスがあっただけでも、WordPressでよくあるエラーを引き起こしたり、サイトが完全に壊れてしまったりする可能性があるからです。また、WordPressテーマを更新すると、カスタムコードも失われてしまいます。

そのため、WPCodeの使用をお勧めします。WordPressのコアファイルを編集することなく、WordPressにカスタムコードを追加する最も簡単で安全な方法です。

:あなたのWordPressサイトを安全にカスタマイズするためにWPCodeを使用することができるさまざまな方法が大量にあります。コードスニペットライブラリがビルトインされており、PHP、JavaScript、CSS、HTMLなど、WordPressで最も重要な言語をすべてサポートしています。プラグインの詳細については、WPCodeのレビューをご覧ください。

最初に行う必要があるのは、無料のWPCodeプラグインをインストールして有効化することです。詳しくは、WordPressプラグインのインストール方法のステップバイステップガイドをご覧ください。

有効化したら、WordPressダッシュボードのCode Snippets “ Add Snippetにアクセスしてください。

Adding a code snippet using the WPCode WordPress plugin

コメントを完全に無効化するスニペットや、WordPressが通常サポートしていないファイルタイプのアップロード、添付ファイルの無効化など、サイトに追加できるスニペットがすべて表示されます。

独自のスニペットを作成するには、「カスタムコードを追加」にマウスオーバーし、「スニペットを使用」をクリックします。

Adding a custom snippet to your WordPress website

はじめに、カスタムコードスニペットのタイトルを入力します。これは、WordPressダッシュボードでスニペットを識別するのに役立つものであれば何でもかまいません。

その後、「コードタイプ」のドロップダウンを開き、「PHPスニペット」を選択する。

Adding a custom navigation menu using WPCode

それができたら、以下のスニペットをコードエディターに貼り付けるだけだ:

function wpb_custom_new_menu() {
  register_nav_menu('my-custom-menu',__( 'My Custom Menu' ));
}
add_action( 'init', 'wpb_custom_new_menu' );

これであなたのテーマに「マイカスタムメニュー」という新しいメニューの場所が追加されます。別の名前を使うには、コードスニペットを調整するだけです。

テーマに複数のカスタマイザーナビゲーションメニューを追加したい場合は、コードスニペットに1行追加するだけです。

例えば、ここでは「マイカスタムメニュー」と「エクストラメニュー:」という2つの新規メニューをテーマに追加しています。

function wpb_custom_new_menu() {
  register_nav_menus(
    array(
      'my-custom-menu' => __( 'My Custom Menu' ),
      'extra-menu' => __( 'Extra Menu' )
    )
  );
}
add_action( 'init', 'wpb_custom_new_menu' );

その後、「インサーター」オプションまでスクロールします。すでに選択されていない場合は、「自動挿入」を選択し、WPCodeがサイト全体にスニペットを追加します。

その後、『場所』のドロップダウンを開き、『どこでも実行』をクリックする。

Running a custom code snippet

次に、画面を一番上までスクロールし、「Inactive」トグルをクリックして「Active」に変更します。

最後に、「保存」をクリックして、このスニペットをライブにする。

Inserting a custom navigation menu using the WPCode WordPress plugin

その後、外観 ” メニューを開き、「表示場所」エリアを見てください。

これで新しい「マイカスタムメニュー」オプションが表示されるはずです。

A custom navigation menu created using the WPCode plugin

これで、新しい場所にメニュー項目を追加することができます。詳しくは、初心者のためのナビゲーションメニューの追加方法のステップバイステップガイドをご覧ください。

メニューに満足したら、次のステップはWordPressテーマに追加することです。

WordPressテーマにカスタムナビゲーションメニューを追加する

ほとんどのサイトでは、ヘッダーセクションの直下にナビゲーションメニューが表示されています。つまり、メニューはサイトのロゴやタイトルと並んで、訪問者が最初に目にするもののひとつなのです。

テーマのテンプレートファイルにコードを追加することで、カスタムナビゲーションメニューを任意の場所に追加することができます。

WordPressのダッシュボードで、外観 ” テーマファイルエディターに進みます。

右側のメニューで、メニューを追加したいテンプレートを選択します。例えば、カスタムナビゲーションメニューをサイトのヘッダーに表示したい場合は、通常header.phpファイルを選択します。

The WordPress theme file editor

適切なテンプレートファイルの見つけ方については、WordPressテーマで編集するファイルの見つけ方をご覧ください。

ファイルを選択した後、wp_nav_menu関数を追加し、カスタムメニューの名前を指定する必要があります。

例えば、以下のコードスニペットでは、テーマのヘッダーに「マイカスタムメニュー」を追加しています:

wp_nav_menu( array( 'theme_location'=>'my-custom-menu', 'container_class'=>'custom-menu-class' ) );

コードを追加したら、「ファイルを更新」ボタンをクリックして変更を保存します。

Editing the WordPress theme files

さて、あなたのサイトにアクセスすると、カスタムメニューが表示されます。

初期設定では、メニューは箇条書きリストとして表示されます。

A custom WordPress menu created using code

カスタムCSSコードをサイトに追加することで、カスタムナビゲーションメニューをWordPressテーマや企業ブランディングに一致するようにスタイル設定することができます。

これを行うには、外観 ” カスタマイザーに進みます。

Customizing a WordPress theme

WordPressのテーマカスタマイザーで、「Additional CSS」をクリックします。

小さなコードエディターが開き、CSSを入力することができます。

Adding additional CSS to your WordPress theme

テーマのテンプレートに追加したCSSクラスを使って、メニューのスタイルを設定できます。私たちの例では、これは.custom_menu_classです。

以下のコードでは、余白とパディングを追加し、テキストの色を黒に設定し、メニュー項目を水平レイアウトにしている:

div.custom-menu-class ul {
    margin:20px 0px 20px 0px;
    list-style-type: none;
    list-style: none;
    list-style-image: none;
    text-align:right;
	display:inline-block;
}
div.custom-menu-class li {
    padding: 0px 20px 0px 0px;
    display: inline-block;
} 

div.custom-menu-class a {
    color:#000;
}

WordPressカスタマイザーは自動的に更新されます。

これでメニューが新しいスタイルでどのように見えるかが表示されます。

Styling a custom navigation menu

メニューの見た目に問題がなければ、「公開する」をクリックして変更を反映させます。

詳しくは、WordPressナビゲーションメニューのスタイリング方法をご覧ください。

エキスパートガイド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.

Disclosure: Our content is reader-supported. This means if you click on some of our links, then we may earn a commission. See how WPBeginner is funded, why it matters, and how you can support us. Here's our editorial process.

アバター

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.

The Ultimate WordPress Toolkit

Get FREE access to our toolkit - a collection of WordPress related products and resources that every professional should have!

Reader Interactions

99件のコメントLeave a Reply

  1. Jiří Vaněk

    I always wanted to avoid the plugin first for things like this. That’s why I always appreciate it when you also offer the option of using WP Code and snippets. I always try them on a test site first and this one works great. I then save your snippets in my own code store, which I can always return to if necessary. Thanks.

    • WPBeginner Support

      Glad to hear you found our code snippets helpful! :)

      Admin

  2. Mike

    Thanks for show the code, I have an issue, my new new always shows same content as main menu after I applied:
    wp_nav_menu( array( ‘theme_location’=>’too-right-menu’, ‘container_class’=>’top-right-class’ ) );

    Please help.

    • WPBeginner Support

      You may be using the same name as a different menu that your theme has active. If you have not done so already, please try a different location name.

      Admin

  3. Shubham Kumar

    How can create that menu sticky, I use the first method ie. to paste the code in theme’s header.php, now I would like to sticky that element if the user scrolls to from that menu location.

  4. Amit Singh

    I created two menus. One in left of logo and other in right. Now I want to add sub menu. I m just dragging menus under parent but it’s not working. Do you have any article explain how we can add custom submenu

    • WPBeginner Support

      Not at the moment but we will certainly take that into consideration for future articles.

      Admin

  5. Mohit

    Keep doing the great work

    • WPBeginner Support

      Glad you continue to enjoy our content :)

      Admin

  6. Saurabh

    my menu is not display in header. it display below the page title

    • WPBeginner Support

      You may need to modify where the code is inserted in the template but if you reach out to your current theme’s support they should be able to let you know where the header is added in their theme.

      Admin

  7. ian

    hello

    why can’t i see the menus page of my website?

    the layout of the tutorials look absolutely nothing like my screen

    thanks

  8. krishna

    hello
    i want to add my own html for header
    how can i do that ?

  9. Mukeshwar Singh

    Hey, I am using Magazine Pro and There is no option of Custom Menu in Widgets Area!! I Used your code to create a Custom Menu but I need help because there is no option of Custom Menu in the Widget area because of Which I cannot Drag and drop that into the footer area… Please help me

  10. Elle

    Hey! I completed the tutorial and I’ve been able to add the menu to my desired location on my site. I’ve styled it and everything. PROBLEM: The menu appears on page refresh for a moment I can even click it! However, it quickly disappears behind my header. It’s not clickable after it disappears. My brain’s exploding trying to figure this one out!!

  11. Furqan

    Hi
    First I create the add menu with a name my custom menu and its perfectly fine and proper fetch and then I changed its name to footer menu after changed its name custom navigation not fetch what the reason

  12. Himanshu

    Just one ques : what should I do with the existing navbar of WordPress . How to delete it.

  13. karima

    Hi, Friend of mine has a problem, well several, she has the horizontal header nav bar but also a vertical one next to it which is obscuring the page content , it appears when you start to scroll on the home page but is fixed on all the content pages.. can someone look please and advise, also there is an error notice we can´t find how to get rid of, any help please appreciated.

  14. sudhakar

    how to remove default slider any theme and how to add our new slider model in homepage

Leave A Reply

Thanks for choosing to leave a comment. Please keep in mind that all comments are moderated according to our comment policy, and your email address will NOT be published. Please Do NOT use keywords in the name field. Let's have a personal and meaningful conversation.