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

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

関連

お勧めコンテンツ

get_post_thumbnail_id(2010年7月13日 登録)

int get_post_thumbnail_id( [ int $post_id = null ] )
投稿情報にアイキャッチ画像(サムネイル)として設定されているアタッチメント情報のIDを取得する。

wp_register(2009年12月4日 登録)

void wp_register( [ string $before = '<li>' [ , string $after = '</li>' ] ] )
閲覧者がログインしているかどうかを調べ、ログインしておらず、かつユーザー登録が可能になっていればユーザ登録ページのリンクを、ログイン済みならば管理者ページのリンクを表示する。

get_page_by_path(2012年6月1日 登録)

mixed get_page_by_path( string $page_path [ , string $output = OBJECT [ , string $post_type = 'page' ] ] )
指定されたページ名の投稿情報を取得する。

post_custom(2012年6月21日 登録)

mixed post_custom( [ string $key = '' ] )
カスタムフィールドの値を取得する。

is_front_page(2011年2月17日 登録)

bool is_front_page( )
フロントページか調べる。

最終更新日時 : 2011-07-06 19:47