setup_postdata

説明

bool setup_postdata( stdClass $post )
投稿記事に関連するグローバル変数を設定する。

パラメータ

  • $post
    投稿記事のオブジェクトを指定。

返り値

常にtrueを返す。

注意

query_posts関数や get_posts関数、WP_Queryクラスを使って投稿記事を取得した後のループ処理にて、 the_post関数や wp_reset_postdata関数を使うことでこのsetup_postdata関数が呼び出され、関連するグローバル変数が更新される。
グローバル変数データ型意味
$idint投稿ID
$authordatastdClass投稿者情報(オブジェクト)
$currentdaystring投稿日(書式「日.月.年(2桁)」)
$currentmonthstring投稿月
$pageintページ番号
$pagesarrayページ分割処理後の投稿記事テキストの配列
$multipageintページ分割数
$moreint単一記事またはフィードの場合か、$pageが1より大きい場合は1
$numpagesintページ分割している場合は1、分割していない場合は0
$pagesは投稿記事中の<!--nextpage-->コメントによって分割されたテキストが入る。

使用例

  • 投稿記事$acat_postのグローバル変数を設定する。
    <?php setup_postdata( $acat_post ); ?>

最終更新 : 2014年11月16日 17:40



お勧め

子カテゴリのアーカイブページを親カテゴリ用のテンプレートファイルで表示しよう(2011年12月8日 更新)

少し前に投稿した「適切なテンプレートファイルを用意してテンプレート内の振り分け処理を無くす」で説明した通り、特定のカテゴリ専用のテンプレートとしてcategory-○○.phpを用意することで、category.phpやarchive.php内で振り分けを行う必要がなくなる。ただ、すべてのカテゴリ分を用意するのは効率的ではないし、特に子カテゴリについては親カテゴリと共通内容になるケースが多いのではないだろうか。ここでは、子カテゴリの個別テンプレートファイルを作らず、親カテゴリのテンプレートを利用する方法を紹介する。

固定ページを投稿ページ用テンプレートファイル(single.php)で表示する(2013年7月31日 更新)

固定ページと投稿ページのデザインが共通の場合、同じ内容のsingle.phpとpage.phpを用意すれば事足りるが、デザインの修正時は二度手間になってしまう。そこで、固定ページをsingle.phpで表示するようにできないか考えてみた。

もうquery_postsは呼ばない(2011年9月27日 更新)

トップページやカテゴリーページで標準の条件に少し手を加えた投稿情報を表示するケースがある。そんな時、テンプレートファイルの先頭で query_posts関数を呼び出して投稿情報を再抽出していたのだが、フィルター処理をうまく使えばquery_posts関数を呼び出さなくても大丈夫みたいだ。

使っていないか確認しないとね!(2017年11月18日 更新)

2003年に誕生したWordPress。その歴史の中には、廃止予定(deprecated)となっている関数がいくつも存在する。それらの関数をテーマやプラグインで使用するべきではないし、使用しているなら代替の関数に書き換えるべきである。ここでは3.24.9.0現在、廃止予定となっている関数をまとめて紹介する。

ホームディレクトリから過去のファイルを削除する(2013年1月27日 更新)

WordPressで構築したサイトのホームディレクトリには、現在使われていないファイルが残っている時がある。3.5.1もリリースされたことだし、これを機にホームディレクトリを整理整頓した。