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テーマ内にショートコードを追加したい場合もあります。

この投稿では、WordPressテーマに任意のショートコードを簡単に追加する方法を紹介します。

How to use shortcodes in your WordPress themes

なぜWordPressテーマでショートコードを使うのか?

ショートコードは、画像ギャラリー、フォーム、ソーシャルメディアフィードなど、サイトにさまざまな機能を追加できます。

WordPressにはいくつかのショートコードがビルトインされていますが、サイトにショートコードを追加する人気のWordPressプラグインもたくさんあります。

例えば、WPFormsには使いやすいブロックがありますが、ショートコードも提供されているので、サイトの他のエリアにフォームを追加することもできます。

An example of a WordPress shortcode, provided by WPForms

ほとんどの場合、投稿やページなどのコンテンツエリア内にショートコードを追加します。

さらに詳しく知りたい方は、WordPressでショートコードを追加する方法の完全ガイドをご覧ください。

Adding a shortcode block to a WordPress page or post

しかし、WordPressテーマファイル内でショートコードを使いたい場合もあるでしょう。

これにより、アーカイブページなど、WordPress標準の投稿エディターでは編集できないエリアに動的要素を追加することができます。また、複数のページで同じショートコードを使用する簡単な方法でもあります。

例えば、テーマのページや投稿テンプレートにショートコードを追加することができます。

それでは、WordPressテーマでショートコードを使う方法を見ていきましょう。以下のクイックリンクから、使いたい方法にジャンプしてください:

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

WordPressテーマでショートコードを使用する最も簡単な方法は、フルサイトエディターを使用することです。これにより、サイトのどの部分にもショートコードブロックを追加することができます。

ただし、この方法はHestia Proのようなブロックベースのテーマでしか使えません。ブロック有効化テーマを使っていない場合は、別の方法を使う必要がある。

始めるには、WordPressダッシュボードの外観 ” エディターへ向かいます。

Opening the WordPress full-site editor (FSE)

初期設定では、フルサイトエディターはテーマのホームテンプレートを表示しますが、どのテンプレートにもショートコードを追加できます。

利用可能なオプションをすべて表示するには、「テンプレート」を選択します。

Adding shortcode to a WordPress template using the full-site editor

編集したいテンプレートをクリックしてください。

例として、404ページのテンプレートにショートコードを追加してみますが、どのテンプレートを選んでも手順は全く同じです。

Adding a shortcode to a WordPress theme using a full-site editor (FSE)

WordPressにテンプレートのプレビューが表示されます。

ショートコードを追加するには、小さな鉛筆のアイコンをクリックしてください。

Editing a WordPress theme's 404 template using the full-site editor (FSE)

それが終わったら、左上の青い「+」アイコンをクリックする。

検索バーに「Shortcode」と入力してください。

Adding a shortcode block to a WordPress theme

適切なブロックが外観されたら、テーマテンプレートにドラッグ&ドロップする。

使いたいショートコードを貼り付けるか、入力する。

Adding Shortcode blocks to a WordPress theme

その後、「保存」ボタンをクリックしてください。

では、WordPressのブログにアクセスして、ショートコードの動きを見てみよう。

An example of a shortcode, on a 404 page template

方法2:WordPressテーマファイルを編集する(どのWordPressテーマでも使えます)

テーマファイルを編集することで、WordPressテーマにショートコードを追加することもできる。この方法はより高度ですが、すべてのWordPressテーマで動作します。

サイトにコードを追加したことがない場合は、WordPressでコードをコピー&ペーストする方法のステップバイステップガイドをご覧ください。

個々のテーマファイルを直接変更することもできますが、その場合、カスタマイザーを失うことなくWordPressテーマを更新することが難しくなります。そのため、子テーマを作成してテーマファイルを上書きすることをお勧めします。

カスタマイザーを作成している場合は、既存のテーマファイルにコードを追加または修正することができます。

テーマファイルを編集する際、標準のコンテンツエリアで使用するのと同じフォーマットでショートコードを追加することはできません。ショートコードの出力を見る代わりに、ショートコードそのものが画面に表示されます。

これは、WordPressがテーマのテンプレートファイル内でショートコードを実行しないために起こります。代わりに、do_shortcode関数を使用してショートコードを実行するようにWordPressに明示的に指示する必要があります。

詳しくは、カスタムコードを簡単に追加する方法をご覧ください。

WordPressテーマファイルに追加するコードの例です:

echo do_shortcode('[gallery]');

ギャラリー」を使用したいショートコードに置き換えるだけです。

ショートコードをどこに追加すればよいかわからない場合は、WordPressテンプレート階層の初心者ガイドをご覧ください。

追加のパラメータを持つショートコードを追加する場合は、少し異なるコードスニペットを使用する必要があります。

WPForms を使ってお問い合わせフォームを作成したとします。この場合、標準の WPForms ショートコードとフォームの ID を使う必要があります:

echo do_shortcode("[wpforms id='92']");

トラブルシューティング:do_shortcodeが動作しない場合の対処法

テーマファイルにショートコードを追加しても、WordPressサイトに出力されないことがあります。これは通常、ショートコードがWordPressプラグインやサイト上の他のコードに依存していることを意味します。

do_shortcode関数が動作しない場合は、プラグイン ” インストール済みプラグインにアクセスして、ショートコードを提供するプラグインがインストールされ有効化されていることを確認してください。

以下の画像では、WPFormsはインストールされていますが無効化されているので、echo do_shortcodeコードは動作しません。

How to instal and activate a WordPress plugin

ショートコードが利用可能かどうかは、index.phpファイルにshortcode_exists()関数を追加することでも確認できます。

以下のスニペットでは、WPFormsスニペットがサイトで使用可能かどうかをチェックしています:

if ( shortcode_exists( 'wpforms' ))  {
  echo do_shortcode("[[wpforms id='147']]");
}

それでもサイト上にショートコードの出力が表示されない場合は、古いバージョンのサイトが表示されている可能性があるため、WordPressのキャッシュをクリアしてみてください。

方法3:独自のWordPressテーマを作成する(フルカスタマイズ可能)

もうひとつのオプションは、カスタマイザーでWordPressテーマを作成することだ。これはより高度な方法だが、WordPressテーマの好きなエリアに好きなだけショートコードを追加することができる。また、その他の変更も可能で、まさにあなたが望む機能やデザインを作成することができる。

これまで、WordPressのカスタムテーマを作成するには、複雑なチュートリアルに従ったり、カスタムコードを書いたりする必要がありました。しかし、SeedProdを使えば、個別コードを一行も書かずにカスタムテーマを作成できるようになりました。

SeedProdは最高のWordPressページビルダーであり、サイトキットやテンプレート全体と一緒にテーマビルダーも付属しています。これにより、ドラッグ&ドロップで独自のテーマをデザインすることができます。

SeedProd's advanced theme builder feature

ステップバイステップの手順については、カスタムWordPressテーマの作成方法(コードなし)をご覧ください。

テーマを作成した後、SeedProd ” Theme BuilderでWordPressサイトの任意の部分にショートコードを追加することができます。

Custom WordPress theme templates

ここで、ショートコードを使いたいテンプレートを見つけます。

そして、そのテンプレートにマウスオーバーし、外観が表示されたら「Edit Design」をクリックします。

Creating a custom theme using SeedProd

これでSeedProdのテーマビルダーでテンプレートが開きます。

左側のメニューで「Advanced」セクションまでスクロールします。ここでショートコード・ブロックを見つけ、レイアウト上にドラッグします。

Adding a Shortcode block to a theme using SeedProd

ライブプレビューでは、単にクリックしてショートコードブロックを選択します。

ショートコードを「ショートコード」ボックスに追加することができます。

Adding a contact form to a WordPress theme using shortcode

初期設定では、SeedProdはライブプレビューにショートコード出力を表示しません。

ショートコードを表示するには、「ショートコードオプションを表示」をクリックしてください。

Previewing the shortcode output in SeedProd

その後、’Advanced’タブを選択して、ショートコード出力にスタイルを追加したいかもしれない。

ここでは、スペーシングを変更したり、カスタマイザーを追加したり、CSSアニメーション効果を追加することもできる。

Styling shortcode output using the SeedProd theme builder

ページの見栄えに満足したら、「保存」ボタンをクリックします。

その後、’Publish’を選択してショートコードを公開します。

Publishing a custom WordPress theme using SeedProd

カスタムショートコードの動作を確認するには、サイトにアクセスしてください。

このチュートリアルで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

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

  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. Jiří Vaněk says

    Is there a way to create a shortcode myself, rather than just inserting one that’s already created by a plugin? Let me give an example. I create a piece of code that I don’t necessarily want to insert everywhere as PHP code. Can I turn that code into a shortcode, which I then simply insert in the desired location, and the entire PHP code hidden within that shortcode gets executed there?

  3. pankaj says

    I deleted contact form 7 and it is giving error like this [contact-form-7 404 “Not Found”] I don’t want to use the form again but want to remove this error I don’t know where to find that code or shortcode in template file

  4. Sonik says

    hi,

    I have written a shortcode of a gallery plugin in wordpress visual editor, but it is not executing the shortcode, instead it displays the shortcode as it is written.

    like if I write [test attr=’hello’], it echoes the same on webpage, not executing.

    Thanks.

  5. DavidA says

    Hello, I have two wordpress blogs on multisite.
    Do you know, how to use the shortcode on the website 1 from the website 2 ?
    Thx

  6. Dean says

    Sorry here is the code:

    CODE: ——————————————————————————————

    echo do_shortcode(“[tabset tab1=”tab 1 title” tab2=”tab 2 title”]
    [tab]tab 1 content[/tab]

    [tab]tab 2 content[/tab]
    [/tabset]”);

    —————————————————————————————————-

  7. Nate Rouch says

    That’s good information. I’ve been searching for a way to simply add these, I appreciate it.

  8. Tim says

    Great info. Thanks! However, it’s not working for me in WordPress 3.5.1 using the Avada theme.

    Do you need to add anything to functions.php for the code above to work? Could this be a theme-specific issue? Thanks, just learning wordpress templating.

  9. Tyron says

    This is a great little tip. How would this work if your content needs to be wrapped in a shortcode?

    Like [shortcode-name]Content here[/shortcode-name].

    • Jonathon Harris says

      Tyron,
      This a late answer as I’m just seeing it, but to include wrapped content, you could do the following:

      echo do_shortcode(‘[example_shortcode]’.$text_to_be_wrapped_in_shortcode.'[/example_shortcode]’);

      Cheers,
      J

  10. krushna says

    yes..i am also interested to know ..where to write the code. if there will be example that wud be great.

  11. Keith Davis says

    Hi boys
    Where do you add the code…

    What file do you add it to and where abouts in the file?

    My theme already uses shortcodes but it would still be interesting to know.

返信を残す

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