この記事は最後に更新してから1年以上経過しています。

3.2標準テーマ「Twenty Eleven」は投稿フォーマットに着目

説明

新テーマ「Twenty Eleven」のトップページでは、投稿フォーマットに応じて表示を切り替える仕組みが提案されている。ここでは、その投稿フォームの活用方法を簡単に紹介する。 3.2の標準テーマでは、テーマ作成に関わるいくつかの提案(アイデア)が実践されている。その1つが投稿フォーマットの積極的な活用だろう。さっそく、具体的なソースコードを見てみよう。
以前の標準テーマ「Twenty Ten」では投稿記事を繰り返し表示する部分(ループ処理)をloop.phpやloop-●●.phpといった別ファイル分離し、トップページなどを表示するテンプレートのindex.phpでは、次のように記述されていた。
<?php get_template_part( 'loop', 'index' ); ?>
新テーマ「Twenty Eleven」のindex.phpでは、ループ処理のは分離せず、投稿記事を表示する部分のみをcontent.phpやcontent-●●.phpといった投稿フォーマットに応じたファイルに振り分けるようになっている。
<?php while ( have_posts() ) : the_post(); ?>

<?php get_template_part( 'content', get_post_format() ); ?>

<?php endwhile; ?>
投稿時にフォーマットを選択投稿ページでは、記事内容に応じた投稿フォーマットを選択。その投稿記事を表示する際に get_post_format関数で投稿フォーマットの種類を取得し、そのまま get_template_part関数のパラメータとして渡すことで、特に振り分け処理を記述することなく、表示内容を切り替えている。
これまで記事の内容に応じて表示を変更する場合は、カテゴリを利用したり、投稿記事のカスタムフィールドを活用したりしていたわけだが、投稿フォーマットを活用することでテンプレート内の記述もシンプルにできる。独自テーマを作成する際に使えるナイスな提案ですね。

最終更新 : 2011年07月06日 19:47


お勧め

has_category(2012年1月17日 更新)

bool has_category( [ mixed $category = '' [ , mixed $post = null ] ] )
投稿記事がカテゴリーに属しているか調べる。

comments_template(2018年5月27日 更新)

void comments_template( string $file = '/comments.php' , bool $separate_comments = false )
投稿ページ(post)または単一ページ(page)のコメント情報を取得し、コメント表示・投稿用のテンプレートファイルを読み込んで表示する。

is_taxonomy_hierarchical(2018年5月27日 更新)

bool is_taxonomy_hierarchical( string $taxonomy )
タクソノミーに階層(親子)関係があるか調べる。

send_confirmation_on_profile_email(2018年5月27日 更新)

void send_confirmation_on_profile_email()
メールアドレス変更を確認するメールを送信する。

get_the_modified_time(2023年9月20日 更新)

string | int | false get_the_modified_time( [ string $format = '' [ , int | WP_Post $post = null ] ] )
パラメータ$formatで指定したフォーマットで投稿の更新時刻を取得する。