ショートコードを使ってテーマ内の画像URLを簡単に指定する

ショートコードを使ってテーマ内の画像URLを簡単に指定する - 投稿記事でテーマ内の画像を使うなら

説明

投稿記事の中で画像パーツを使いたいときがある。画像パーツの配置場所は、/imgディレクトリのようなテーマ外の場合と、/wp-content/themes/mytheme/imagesディレクトリのようなテーマ内の場合があり、今回は後者のケース。ショートコードを使って投稿記事の画像ファイルのURLを記述する方法を紹介したい。 通常、投稿記事にテーマ内の画像ファイルを入れる場合、
<img src="/wp-content/themes/mytheme/images/logo.gif" />
だったり、プロトコルやドメインを含んだ
<img src="http://localhost/wp-content/themes/mytheme/images/logo.gif" />
となる。 WordPressでは、get_template_directory_uriget_bloginfo( 'template_url' )を使うことで、自テーマのURI部分(上記の「~/mytheme」までの部分)を取得できる。ショートコードを使った投稿記事の記述例は、
<img src="[tp /]/images/logo.gif" />
または
<img src="[tp]/images/logo.gif[/tp]" />
となる。だいぶ短くなりますよね。 テーマ内のfunctions.phpに記述するPHPのコードは次の通り。
add_shortcode( 'tp', 'shortcode_tp' );
function shortcode_tp( $atts, $content = '' ) {
	return get_template_directory_uri().$content;
}
add_shortcodeを使ってショートコードに対応する関数を指定するだけのシンプルなもの。すごく簡単ですよね。

関連

お勧めコンテンツ

add_post_type_support(2012年4月12日 登録)

void add_post_type_support( string $post_type, mixed $feature )
投稿タイプに特徴を追加する。

get_site_url(2010年6月10日 登録)

string get_site_url( [ int $blog_id = null [ , string $path = '' [ , string $scheme = null ] ] ] )
任意のブログのサイトURLを取得する。サイトURLは、管理者ページの「設定」-「一般」の「WordPressのアドレス(URL)」のこと。

wp_get_attachment_link(2011年1月4日 登録)

string wp_get_attachment_link( [ int $id = 0 [ , mixed $size = 'thumbnail' [ , bool $permalink = false [ , bool $icon = false [ , mixed $text = false ] ] ] ] ] )
添付ファイルへのリンクを示すHTMLテキストを取得する。

the_content(2009年11月12日 登録)

void the_content( [ string $more_link_text = null [ , int $stripteaser = 0 [ , string $more_file = '' ] ] ] )
投稿記事の内容のすべてまたは一部を表示する。

wp_attachment_is_image(2014年7月12日 登録)

bool wp_attachment_is_image( [ int $post_id = 0 ] )
メディア投稿(attachment)の添付ファイルが画像ファイルか調べる。

最終更新日時 : 2011-05-07 22:35