質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
WordPress

WordPressは、PHPで開発されているオープンソースのブログソフトウェアです。データベース管理システムにはMySQLを用いています。フリーのブログソフトウェアの中では最も人気が高く、PHPとHTMLを使って簡単にテンプレートをカスタマイズすることができます。

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

Q&A

解決済

1回答

988閲覧

WordPressオリジナルテーマの記事内でショートコードがそのまま表示されてしまいます。

shoji0014

総合スコア11

WordPress

WordPressは、PHPで開発されているオープンソースのブログソフトウェアです。データベース管理システムにはMySQLを用いています。フリーのブログソフトウェアの中では最も人気が高く、PHPとHTMLを使って簡単にテンプレートをカスタマイズすることができます。

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

0グッド

0クリップ

投稿2019/01/30 08:45

WordPressにてオリジナルテーマを0から作成したサイトがあるのですが、記事内にMetaSliderというプラグインで生成したショートコードを貼り付けたところコードがそのまま表示されてしまいます。
こちらの記事になるようなオリジナルテーマでありがちな下記の表記も問題ありません。

<?php wp_head(); ?> </head> <?php wp_footer(); ?> </body>

基本テーマのtwentysixteenなどにすると動作しますし、single.php以外のheader.phpなどに、下記のようにショートコードを呼び出しても動作します。

<?php echo do_shortcode('[metaslider id="336"]'); ?>

ちなみにこちらがsingle.phpのコードですが何かおかしな部分があるのでしょうか?

<?php get_header(); ?> <div class="main_contents"> <article class="sp_wrapper"> <div class="content_single_article content_line content_bottom_single"> <div class="single_image fadein"> <h1 class="fadein"> <?php the_title_attribute(); ?> </h1> <?php if ( has_post_thumbnail() ) { the_post_thumbnail(); } else { echo '<img src="' . get_bloginfo( 'template_directory' ) . '/images/thumbnail.png">'; } ?> <p> <?php $this_content= wpautop($post->post_content); echo $this_content; ?> </p> </div> </div> </article> <article> <div class="related_article"> <h2> <div class="title_line fadein"> Related Article </div> </h2> <div class="content"> <?php // 同じカテゴリから記事を10件呼び出す $categories = get_the_category($post->ID); $category_ID = array(); foreach($categories as $category): array_push( $category_ID, $category -> cat_ID); endforeach ; $args = array( 'post__not_in' => array($post -> ID), // 今読んでいる記事を除く 'posts_per_page'=> 3, 'category__in' => $category_ID, 'orderby' => 'rand', // ランダムに記事を選ぶ ); $query = new WP_Query($args); if( $query -> have_posts() ): while ($query -> have_posts()) : $query -> the_post(); ?> <div class="content_size"> <a href="<?php the_permalink(); ?>"> <div class="frontcatch_size fadein"> <?php the_post_thumbnail( 'thumb300'); ?> <div class="post_body"> <?php if(mb_strlen($post->post_title, 'UTF-8')>13){ $title= mb_substr($post->post_title, 0, 13, 'UTF-8'); echo $title.'……'; }else{ echo $post->post_title; } ?> </div> </div> </a> </div> <?php endwhile; ?> <?php else : ?> <p>記事が見つかりません</p> <?php endif; ?> <?php wp_reset_postdata(); wp_reset_query(); ?> </div> </div> </article> </div> </div> <!-- /contents --> <?php get_footer(); ?>

もし原因がお分かりの方がいらっしゃればご回答頂けると助かります。
よろしくお願いいたします。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

このあたりを確認してみてください。

【$post->post_content;は整形前の生のデータを抜き出してしまう | ハックノート】
https://hacknote.jp/archives/4148/

【get_the_content, the_contentで、本文出力を使いこなす | WWWクリエイターズ】
http://www-creators.com/archives/1259

投稿2019/01/30 10:00

kei344

総合スコア69407

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

shoji0014

2019/01/31 01:15

参考にいただいた記事を元に本文の出力方法を変えたところ動作してくれました。 ありがとうございました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問